:root {
  --midnight: #15243b;
  --ocean: #1f4e79;
  --teal: #56c7c9;
  --sand: #e6d5b6;
  --slate: #2f3448;
  --mist: #f4f7f5;
  --white: #f8fafc;
  --deep: #08111c;
  --harbor: #0e1b2d;
  --line: rgba(21, 36, 59, 0.12);
  --soft-shadow: 0 24px 80px rgba(8, 17, 28, 0.12);
  --hard-shadow: 0 34px 110px rgba(8, 17, 28, 0.32);
  --radius-lg: 34px;
  --radius-md: 24px;
  --radius-sm: 16px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background:
    radial-gradient(circle at 12% 0%, rgba(86, 199, 201, 0.18), transparent 26rem),
    linear-gradient(180deg, #f6f8f6 0%, var(--mist) 46%, #edf4f4 100%);
  color: var(--midnight);
  font-family: "Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.5;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  display: block;
  max-width: 100%;
}

.site-header {
  align-items: center;
  background: rgba(248, 250, 252, 0.86);
  backdrop-filter: blur(22px);
  border: 1px solid rgba(21, 36, 59, 0.08);
  border-radius: 999px;
  box-shadow: 0 14px 55px rgba(8, 17, 28, 0.09);
  display: flex;
  gap: 18px;
  justify-content: space-between;
  left: clamp(14px, 3vw, 42px);
  padding: 10px 12px 10px 18px;
  position: fixed;
  right: clamp(14px, 3vw, 42px);
  top: 18px;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
  z-index: 30;
}

.site-header.is-scrolled {
  background: rgba(248, 250, 252, 0.94);
  box-shadow: 0 18px 60px rgba(8, 17, 28, 0.14);
  transform: translateY(-4px);
}

.brand {
  align-items: center;
  display: inline-flex;
  gap: 10px;
  min-width: max-content;
}

.brand-mark {
  align-items: center;
  background: var(--midnight);
  border-radius: 999px;
  box-shadow: inset 0 0 0 2px rgba(86, 199, 201, 0.55);
  color: var(--white);
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  height: 42px;
  justify-content: center;
  width: 42px;
}

.brand strong {
  display: block;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: 0;
}

.brand small {
  color: rgba(47, 52, 72, 0.68);
  display: block;
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
}

.desktop-nav {
  align-items: center;
  background: rgba(21, 36, 59, 0.04);
  border: 1px solid rgba(21, 36, 59, 0.06);
  border-radius: 999px;
  display: flex;
  gap: 3px;
  padding: 5px;
}

.desktop-nav a,
.nav-cta,
.button {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  font-size: 13px;
  font-weight: 800;
  justify-content: center;
  min-height: 40px;
  padding: 10px 15px;
  transition: transform 180ms ease, background 180ms ease, color 180ms ease, box-shadow 180ms ease;
}

.desktop-nav a {
  color: rgba(47, 52, 72, 0.78);
}

.desktop-nav a:hover,
.desktop-nav a:focus-visible {
  background: var(--white);
  color: var(--ocean);
  box-shadow: 0 10px 30px rgba(8, 17, 28, 0.08);
}

.nav-cta,
.button.primary {
  background: var(--midnight);
  color: var(--white);
  box-shadow: 0 12px 36px rgba(21, 36, 59, 0.2);
}

.button.secondary {
  background: rgba(248, 250, 252, 0.82);
  color: var(--midnight);
  box-shadow: inset 0 0 0 1px rgba(21, 36, 59, 0.09);
}

.nav-cta:hover,
.button.primary:hover,
.button.secondary:hover {
  transform: translateY(-2px);
}

.menu-toggle {
  align-items: center;
  background: rgba(21, 36, 59, 0.05);
  border: 0;
  border-radius: 999px;
  display: none;
  flex-direction: column;
  gap: 4px;
  height: 42px;
  justify-content: center;
  width: 42px;
}

.menu-toggle span {
  background: var(--midnight);
  display: block;
  height: 2px;
  width: 17px;
}

.mobile-nav {
  background: rgba(248, 250, 252, 0.96);
  backdrop-filter: blur(22px);
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--soft-shadow);
  display: none;
  left: 18px;
  padding: 14px;
  position: fixed;
  right: 18px;
  top: 86px;
  z-index: 29;
}

.mobile-nav.is-open {
  display: grid;
  gap: 6px;
}

.mobile-nav a {
  border-radius: 999px;
  color: var(--midnight);
  font-weight: 800;
  padding: 13px 16px;
}

.mobile-nav a:hover {
  background: rgba(21, 36, 59, 0.05);
}

.hero {
  align-items: center;
  display: grid;
  gap: clamp(24px, 4vw, 46px);
  grid-template-columns: minmax(360px, 0.96fr) minmax(420px, 1.04fr);
  min-height: 82vh;
  overflow: hidden;
  padding: 116px clamp(18px, 4vw, 54px) 34px;
  position: relative;
}

.hero::before {
  background:
    radial-gradient(circle at center, rgba(86, 199, 201, 0.24), transparent 28%),
    repeating-radial-gradient(ellipse at center, rgba(31, 78, 121, 0.22) 0 1px, transparent 1px 34px);
  content: "";
  height: 720px;
  left: -250px;
  opacity: 0.34;
  position: absolute;
  top: 80px;
  transform: rotate(-12deg);
  width: 920px;
}

.hero-content {
  align-self: center;
  max-width: 760px;
  position: relative;
  z-index: 2;
}

.slide-count {
  color: rgba(47, 52, 72, 0.56);
  font-size: 14px;
  font-weight: 800;
  margin: 0 0 20px;
}

.eyebrow {
  color: var(--ocean);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0;
  margin: 0 0 16px;
  text-transform: uppercase;
}

h1,
h2,
h3 {
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1.03;
  margin: 0;
}

h1 {
  font-size: clamp(38px, 3.45vw, 48px);
  max-width: 920px;
}

h2 {
  font-size: clamp(34px, 4.5vw, 62px);
}

h3 {
  font-size: 22px;
  line-height: 1.12;
}

.hero-copy {
  color: rgba(47, 52, 72, 0.78);
  font-size: clamp(16px, 1.55vw, 20px);
  font-weight: 600;
  margin: 24px 0 0;
  max-width: 690px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 30px;
}

.hero-metrics {
  display: none;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 32px 0 0;
}

.hero-metrics div {
  background: rgba(248, 250, 252, 0.72);
  border: 1px solid rgba(21, 36, 59, 0.08);
  border-radius: 999px;
  box-shadow: 0 12px 36px rgba(8, 17, 28, 0.06);
  padding: 13px 16px;
}

.hero-metrics dt {
  color: var(--ocean);
  font-size: 24px;
  font-weight: 900;
}

.hero-metrics dd {
  color: rgba(47, 52, 72, 0.72);
  font-size: 12px;
  font-weight: 800;
  margin: 0;
}

.hero-media-card {
  align-self: center;
  background: var(--sand);
  border: 1px solid rgba(21, 36, 59, 0.1);
  border-radius: var(--radius-lg);
  box-shadow: var(--hard-shadow);
  height: clamp(430px, 42vw, 530px);
  min-height: 0;
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.hero-image {
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  position: absolute;
  transition: opacity 620ms ease, transform 2200ms ease;
  transform: scale(1.025);
  width: 100%;
}

.hero-image.is-active {
  opacity: 1;
  transform: scale(1);
}

.hero-media-card::after {
  background: linear-gradient(180deg, transparent 30%, rgba(8, 17, 28, 0.56) 100%);
  content: "";
  inset: 0;
  position: absolute;
}

.flow-lines {
  inset: -12% -16%;
  pointer-events: none;
  position: absolute;
  z-index: 2;
}

.flow-lines span {
  border: 2px solid rgba(86, 199, 201, 0.5);
  border-left-color: transparent;
  border-radius: 50%;
  display: block;
  height: 42%;
  left: 4%;
  position: absolute;
  top: 18%;
  transform: rotate(-16deg);
  width: 110%;
}

.flow-lines span:nth-child(2) {
  border-color: rgba(230, 213, 182, 0.45);
  border-left-color: transparent;
  height: 52%;
  top: 25%;
}

.flow-lines span:nth-child(3) {
  height: 66%;
  top: 34%;
}

.flow-lines span:nth-child(4) {
  border-color: rgba(31, 78, 121, 0.52);
  border-left-color: transparent;
  height: 76%;
  top: 5%;
}

.hero-arrow {
  align-items: center;
  background: rgba(248, 250, 252, 0.12);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(248, 250, 252, 0.18);
  border-radius: 999px;
  color: var(--white);
  display: inline-flex;
  font-size: 34px;
  height: 54px;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
  z-index: 3;
}

.hero-arrow-left {
  left: 24px;
}

.hero-arrow-right {
  right: 24px;
}

.hero-dots {
  align-items: center;
  bottom: 28px;
  display: flex;
  gap: 8px;
  justify-content: center;
  left: 0;
  position: absolute;
  right: 0;
  z-index: 3;
}

.hero-dots span {
  background: rgba(248, 250, 252, 0.58);
  border-radius: 999px;
  height: 6px;
  width: 22px;
}

.hero-dots .active {
  background: var(--white);
  width: 58px;
}

.section {
  padding: clamp(78px, 9vw, 126px) clamp(18px, 5vw, 70px);
}

.section-heading {
  margin: 0 auto 48px;
  max-width: 960px;
  text-align: center;
}

.section-heading.compact {
  max-width: 900px;
}

.section-heading p:not(.eyebrow) {
  color: rgba(47, 52, 72, 0.72);
  font-size: 18px;
  font-weight: 600;
  margin: 18px auto 0;
}

.ecosystem,
.solutions,
.features {
  background: var(--deep);
  color: var(--white);
}

.testimonial {
  background:
    linear-gradient(90deg, #f7f8f4 0 58%, rgba(247, 248, 244, 0.88) 58% 100%),
    url("./hero-maritime-intelligence.png") right center / auto 100% no-repeat;
  color: var(--midnight);
  overflow: hidden;
  position: relative;
}

.testimonial::before {
  background:
    linear-gradient(90deg, rgba(31, 78, 121, 0.12) 1px, transparent 1px),
    linear-gradient(rgba(31, 78, 121, 0.08) 1px, transparent 1px);
  background-size: 44px 44px;
  content: "";
  inset: 0;
  opacity: 0.28;
  pointer-events: none;
  position: absolute;
}

.testimonial-inner {
  align-items: start;
  display: grid;
  gap: clamp(26px, 4vw, 60px);
  grid-template-columns: 160px minmax(0, 1fr) 190px;
  margin: 0 auto;
  max-width: 1180px;
  position: relative;
}

.testimonial-rail {
  border-top: 2px solid rgba(31, 78, 121, 0.34);
  color: rgba(31, 78, 121, 0.72);
  padding-top: 18px;
  text-transform: uppercase;
}

.testimonial-rail span {
  display: block;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.16em;
  margin-bottom: 14px;
}

.testimonial-rail strong {
  color: var(--midnight);
  display: block;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.35;
}

.testimonial blockquote {
  margin: 0;
  max-width: 780px;
}

.testimonial blockquote > p {
  color: var(--midnight);
  font-size: clamp(29px, 4.1vw, 54px);
  font-weight: 850;
  letter-spacing: 0;
  line-height: 1.12;
  text-wrap: balance;
}

.testimonial blockquote > p::before {
  color: var(--teal);
  content: "“";
  font-size: 1.35em;
  line-height: 0;
  margin-left: -0.48em;
  vertical-align: -0.18em;
}

.testimonial blockquote > p::after {
  color: var(--teal);
  content: "”";
}

.testimonial footer {
  align-items: center;
  border-top: 1px solid rgba(21, 36, 59, 0.16);
  display: grid;
  gap: 8px 18px;
  grid-template-columns: auto 1fr;
  margin-top: clamp(28px, 4vw, 46px);
  padding-top: 20px;
}

.testimonial-mark {
  background: rgba(31, 78, 121, 0.1);
  color: rgba(31, 78, 121, 0.8);
  display: inline-flex;
  font-size: 11px;
  font-weight: 900;
  grid-column: 1 / -1;
  letter-spacing: 0.12em;
  padding: 8px 10px;
  text-transform: uppercase;
  width: fit-content;
}

.testimonial footer strong {
  color: var(--midnight);
  font-size: 22px;
  font-weight: 900;
}

.testimonial footer span:not(.testimonial-mark) {
  color: rgba(21, 36, 59, 0.62);
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.testimonial-seal {
  align-items: center;
  align-self: end;
  aspect-ratio: 1;
  background:
    radial-gradient(circle at 30% 24%, rgba(255, 255, 255, 0.95), rgba(199, 222, 242, 0.88) 42%, rgba(31, 78, 121, 0.92));
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 999px;
  box-shadow: 0 28px 70px rgba(8, 17, 28, 0.22), inset 12px 16px 30px rgba(255, 255, 255, 0.54);
  color: var(--midnight);
  display: flex;
  flex-direction: column;
  justify-content: center;
  justify-self: end;
  padding: 24px;
  text-align: center;
  width: 172px;
}

.testimonial-seal span {
  font-size: 38px;
  font-weight: 950;
  line-height: 1;
}

.testimonial-seal small {
  color: rgba(21, 36, 59, 0.68);
  font-size: 11px;
  font-weight: 850;
  line-height: 1.25;
  margin-top: 8px;
  text-transform: uppercase;
}

.resources-about {
  background: var(--deep);
  color: var(--white);
}

.ecosystem .section-heading p:not(.eyebrow),
.solutions .section-heading p:not(.eyebrow),
.features .section-heading p:not(.eyebrow) {
  color: rgba(248, 250, 252, 0.68);
}

.orbit-layout {
  align-items: center;
  display: grid;
  gap: clamp(28px, 5vw, 72px);
  grid-template-columns: minmax(340px, 1.05fr) minmax(280px, 0.95fr);
  margin: 0 auto;
  max-width: 1200px;
}

.orbit-stage {
  aspect-ratio: 1;
  background:
    radial-gradient(circle at center, rgba(86, 199, 201, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(248, 250, 252, 0.08), rgba(248, 250, 252, 0.02));
  border: 1px solid rgba(248, 250, 252, 0.12);
  border-radius: var(--radius-lg);
  box-shadow: var(--hard-shadow);
  min-height: 560px;
  overflow: hidden;
  position: relative;
}

.orbit-stage::before {
  background: repeating-radial-gradient(circle at center, rgba(248, 250, 252, 0.18) 0 1px, transparent 1px 36px);
  content: "";
  inset: -18%;
  position: absolute;
}

.orbit-ring {
  border: 1px solid rgba(86, 199, 201, 0.28);
  border-radius: 999px;
  inset: 15%;
  position: absolute;
}

.ring-one {
  inset: 23%;
}

.ring-two {
  inset: 13%;
}

.ring-three {
  inset: 4%;
}

.orbit-core {
  align-items: center;
  animation: core-float 6s ease-in-out infinite;
  background:
    radial-gradient(circle at 32% 20%, rgba(255, 255, 255, 0.98) 0 12%, rgba(211, 232, 255, 0.95) 30%, rgba(149, 190, 230, 0.94) 58%, rgba(28, 78, 121, 0.96) 100%);
  border: 1px solid rgba(248, 250, 252, 0.76);
  border-radius: 999px;
  box-shadow:
    0 34px 80px rgba(8, 17, 28, 0.46),
    0 14px 34px rgba(86, 199, 201, 0.18),
    inset -18px -24px 42px rgba(8, 17, 28, 0.22),
    inset 14px 18px 32px rgba(255, 255, 255, 0.72);
  color: var(--midnight);
  display: flex;
  flex-direction: column;
  gap: 9px;
  height: 206px;
  justify-content: center;
  left: 50%;
  padding: 28px;
  position: absolute;
  text-align: center;
  top: 50%;
  transform: translate(-50%, -50%) perspective(700px) rotateX(10deg) rotateY(-13deg);
  transform-style: preserve-3d;
  width: 206px;
  z-index: 2;
}

.orbit-core::before {
  background:
    radial-gradient(circle at 34% 26%, rgba(255, 255, 255, 0.8), rgba(255, 255, 255, 0) 28%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.46), rgba(255, 255, 255, 0.04) 48%, rgba(8, 17, 28, 0.18));
  border-radius: inherit;
  content: "";
  inset: 10px;
  pointer-events: none;
  position: absolute;
  transform: translateZ(16px);
}

.orbit-core::after {
  background: radial-gradient(ellipse at center, rgba(8, 17, 28, 0.38), rgba(8, 17, 28, 0) 66%);
  border-radius: 999px;
  bottom: -28px;
  content: "";
  height: 32px;
  left: 18%;
  pointer-events: none;
  position: absolute;
  transform: translateZ(-42px) rotateX(76deg);
  width: 64%;
}

.orbit-core strong,
.orbit-core span {
  position: relative;
  transform: translateZ(34px);
  z-index: 1;
}

.orbit-core strong {
  color: var(--midnight);
  font-size: 24px;
  font-weight: 900;
  line-height: 1.05;
  text-shadow: 0 2px 0 rgba(255, 255, 255, 0.56), 0 16px 24px rgba(8, 17, 28, 0.2);
}

.orbit-core span {
  color: rgba(21, 36, 59, 0.68);
  font-size: 11px;
  font-weight: 850;
  line-height: 1.45;
}

 core-float {
  0%,
  100% {
    transform: translate(-50%, -50%) perspective(700px) rotateX(10deg) rotateY(-13deg) translateY(0);
  }

  50% {
    transform: translate(-50%, -52%) perspective(700px) rotateX(13deg) rotateY(-8deg) translateY(-4px);
  }
}

.orbit-track {
  animation: orbit-spin var(--orbit-speed, 28s) linear infinite;
  border-radius: 999px;
  inset: 50%;
  position: absolute;
  transform-origin: center;
  z-index: 3;
}

.orbit-stage:hover .orbit-track,
.orbit-stage:focus-within .orbit-track,
.orbit-stage:hover .logo-mark,
.orbit-stage:focus-within .logo-mark {
  animation-play-state: paused;
}

.orbit-track-one {
  --orbit-radius: 205px;
  --orbit-speed: 30s;
}

.orbit-track-two {
  --orbit-radius: 250px;
  --orbit-speed: 42s;
  animation-direction: reverse;
}

.orbit-track-three {
  --orbit-radius: 145px;
  --orbit-speed: 24s;
}

.orbit-logo {
  align-items: center;
  background:
    radial-gradient(circle at 34% 25%, rgba(248, 250, 252, 0.95), rgba(248, 250, 252, 0.54) 42%, rgba(86, 199, 201, 0.18) 100%);
  border: 1px solid rgba(248, 250, 252, 0.28);
  border-radius: 999px;
  box-shadow:
    0 18px 42px rgba(8, 17, 28, 0.28),
    inset 0 0 0 1px rgba(21, 36, 59, 0.06);
  display: inline-flex;
  height: 64px;
  justify-content: center;
  left: 0;
  position: absolute;
  top: 0;
  transform: rotate(var(--angle)) translateX(var(--orbit-radius)) rotate(calc(-1 * var(--angle)));
  transition: box-shadow 180ms ease, background 180ms ease;
  width: 64px;
}

.orbit-logo:hover,
.orbit-logo:focus-visible {
  background: var(--teal);
  box-shadow:
    0 22px 60px rgba(86, 199, 201, 0.34),
    inset 0 0 0 2px rgba(248, 250, 252, 0.44);
  outline: 0;
}

.orbit-logo:hover .logo-mark,
.orbit-logo:focus-visible .logo-mark {
  transform: scale(1.08);
}

.orbit-track-one .logo-mark {
  animation: orbit-counter-spin 30s linear infinite;
}

.orbit-track-two .logo-mark {
  animation: orbit-counter-spin-reverse 42s linear infinite;
}

.orbit-track-three .logo-mark {
  animation: orbit-counter-spin 24s linear infinite;
}

.logo-mark {
  align-items: center;
  background: var(--midnight);
  border-radius: 18px;
  color: var(--teal);
  display: inline-flex;
  height: 38px;
  justify-content: center;
  position: relative;
  transition: transform 180ms ease;
  width: 38px;
}

.logo-performance::before,
.logo-performance::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 4px;
  left: 9px;
  position: absolute;
  width: 20px;
}

.logo-performance::before {
  top: 12px;
}

.logo-performance::after {
  top: 22px;
  width: 14px;
}

.logo-competency::before {
  border: 3px solid currentColor;
  border-radius: 999px;
  content: "";
  height: 15px;
  position: absolute;
  width: 15px;
}

.logo-competency::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 4px;
  position: absolute;
  right: 8px;
  top: 26px;
  transform: rotate(45deg);
  width: 10px;
}

.logo-learning::before {
  border: 3px solid currentColor;
  border-left-color: transparent;
  border-radius: 4px;
  content: "";
  height: 16px;
  position: absolute;
  transform: rotate(-10deg);
  width: 20px;
}

.logo-learning::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 3px;
  position: absolute;
  top: 19px;
  width: 16px;
}

.logo-training::before {
  border: 3px solid currentColor;
  border-radius: 6px;
  content: "";
  height: 18px;
  position: absolute;
  width: 20px;
}

.logo-training::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 3px;
  position: absolute;
  top: 18px;
  width: 18px;
}

.logo-assurance::before {
  border: 3px solid currentColor;
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
  border-bottom-left-radius: 7px;
  border-bottom-right-radius: 7px;
  content: "";
  height: 20px;
  position: absolute;
  top: 8px;
  width: 18px;
}

.logo-assurance::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 8px;
  position: absolute;
  top: 18px;
  width: 8px;
}

.logo-fleet::before {
  border-bottom: 10px solid currentColor;
  border-left: 16px solid transparent;
  border-right: 16px solid transparent;
  content: "";
  position: absolute;
  top: 20px;
}

.logo-fleet::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 3px;
  position: absolute;
  top: 30px;
  width: 25px;
}

.logo-ai::before {
  background:
    radial-gradient(circle, currentColor 0 3px, transparent 4px),
    radial-gradient(circle, currentColor 0 3px, transparent 4px),
    radial-gradient(circle, currentColor 0 3px, transparent 4px);
  background-position: 6px 6px, 22px 10px, 14px 24px;
  background-repeat: no-repeat;
  background-size: 8px 8px;
  content: "";
  inset: 0;
  position: absolute;
}

.logo-ai::after {
  border: 2px solid currentColor;
  border-radius: 999px;
  content: "";
  height: 21px;
  position: absolute;
  width: 21px;
}

.logo-governance::before {
  border: 3px solid currentColor;
  border-radius: 5px;
  content: "";
  height: 18px;
  position: absolute;
  width: 18px;
}

.logo-governance::after {
  background: currentColor;
  border-radius: 999px;
  content: "";
  height: 4px;
  position: absolute;
  top: 17px;
  width: 16px;
}

@keyframes orbit-spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes orbit-counter-spin {
  to {
    transform: rotate(-360deg);
  }
}

@keyframes orbit-counter-spin-reverse {
  to {
    transform: rotate(360deg);
  }
}

.radial-glow {
  animation: center-pulse 2.8s ease-in-out infinite;
  background: linear-gradient(135deg, rgba(86, 199, 201, 0.9), rgba(31, 78, 121, 0.78), rgba(230, 213, 182, 0.58));
  border-radius: 999px;
  box-shadow: 0 0 56px rgba(86, 199, 201, 0.28);
  height: 74px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 74px;
  z-index: 1;
}

.radial-glow::before,
.radial-glow::after {
  animation: sonar-pulse 2.4s ease-out infinite;
  border: 1px solid rgba(248, 250, 252, 0.22);
  border-radius: 999px;
  content: "";
  inset: -14px;
  position: absolute;
}

.radial-glow::after {
  animation-delay: 0.7s;
  inset: -28px;
  opacity: 0.54;
}

.radial-orbit {
  inset: 0;
  position: absolute;
  z-index: 4;
}

.orbit-node {
  align-items: center;
  background: transparent;
  border: 0;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  left: 50%;
  padding: 0;
  position: absolute;
  top: 50%;
  transition: opacity 260ms ease, filter 260ms ease;
}

.orbit-node::before {
  background: radial-gradient(circle, rgba(86, 199, 201, 0.28) 0%, rgba(86, 199, 201, 0) 68%);
  border-radius: 999px;
  content: "";
  height: var(--energy-size, 68px);
  left: 50%;
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: opacity 220ms ease;
  width: var(--energy-size, 68px);
  z-index: -1;
}

.orbit-node.is-related::before,
.orbit-node.is-pulsing::before {
  animation: related-pulse 1.2s ease-in-out infinite;
  opacity: 1;
}

.orbit-node-button {
  align-items: center;
  background:
    radial-gradient(circle at 32% 22%, rgba(248, 250, 252, 0.95), rgba(248, 250, 252, 0.62) 42%, rgba(86, 199, 201, 0.18) 100%);
  border: 2px solid rgba(248, 250, 252, 0.34);
  border-radius: 999px;
  box-shadow: 0 18px 45px rgba(8, 17, 28, 0.24);
  color: var(--teal);
  display: inline-flex;
  height: 54px;
  justify-content: center;
  transition: transform 220ms ease, background 220ms ease, border-color 220ms ease, box-shadow 220ms ease;
  width: 54px;
}

.orbit-node.is-active .orbit-node-button {
  background: var(--white);
  border-color: var(--white);
  box-shadow: 0 24px 70px rgba(248, 250, 252, 0.28);
  color: var(--midnight);
  transform: scale(1.38);
}

.orbit-node.is-related .orbit-node-button {
  background: rgba(248, 250, 252, 0.74);
  border-color: rgba(86, 199, 201, 0.76);
}

.orbit-node-label {
  color: rgba(248, 250, 252, 0.72);
  font-size: 11px;
  font-weight: 850;
  margin-top: 12px;
  max-width: 140px;
  opacity: 0;
  pointer-events: none;
  text-align: center;
  text-shadow: 0 12px 24px rgba(8, 17, 28, 0.45);
  transform: translateY(-4px);
  transition: opacity 220ms ease, transform 220ms ease;
  white-space: nowrap;
}

.orbit-node:hover .orbit-node-label,
.orbit-node:focus-visible .orbit-node-label,
.orbit-node.is-active .orbit-node-label {
  opacity: 1;
  transform: translateY(0);
}

.orbit-node:focus-visible {
  outline: 0;
}

.orbit-node:focus-visible .orbit-node-button {
  box-shadow:
    0 24px 70px rgba(86, 199, 201, 0.28),
    0 0 0 4px rgba(86, 199, 201, 0.2);
}

.orbit-detail {
  background: rgba(8, 17, 28, 0.9);
  border: 1px solid rgba(248, 250, 252, 0.22);
  border-radius: 22px;
  box-shadow: 0 26px 80px rgba(0, 0, 0, 0.42);
  color: var(--white);
  left: 50%;
  max-width: min(290px, calc(100% - 34px));
  padding: 18px;
  position: absolute;
  top: 50%;
  transform: translate(-50%, 96px);
  width: 290px;
  z-index: 8;
}

.orbit-detail::before {
  background: rgba(248, 250, 252, 0.32);
  content: "";
  height: 20px;
  left: 50%;
  position: absolute;
  top: -20px;
  width: 1px;
}

.orbit-detail-top {
  align-items: center;
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.orbit-badge {
  border: 1px solid rgba(248, 250, 252, 0.24);
  border-radius: 999px;
  color: var(--teal);
  font-size: 10px;
  font-weight: 900;
  padding: 5px 9px;
}

.orbit-detail small {
  color: rgba(248, 250, 252, 0.48);
  font-size: 10px;
  font-weight: 800;
}

.orbit-detail h3 {
  font-size: 16px;
  margin-top: 12px;
}

.orbit-detail p {
  color: rgba(248, 250, 252, 0.72);
  font-size: 12px;
  font-weight: 600;
  margin: 9px 0 0;
}

.orbit-energy {
  border-top: 1px solid rgba(248, 250, 252, 0.1);
  margin-top: 14px;
  padding-top: 12px;
}

.orbit-energy-row {
  color: rgba(248, 250, 252, 0.68);
  display: flex;
  font-size: 10px;
  font-weight: 850;
  justify-content: space-between;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.orbit-energy-bar {
  background: rgba(248, 250, 252, 0.1);
  border-radius: 999px;
  height: 5px;
  overflow: hidden;
}

.orbit-energy-bar span {
  background: linear-gradient(90deg, var(--ocean), var(--teal));
  display: block;
  height: 100%;
  width: var(--energy, 70%);
}

.orbit-detail-links {
  border-top: 1px solid rgba(248, 250, 252, 0.1);
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 14px;
  padding-top: 12px;
}

.orbit-detail-links a,
.orbit-detail-action {
  border: 1px solid rgba(248, 250, 252, 0.18);
  border-radius: 999px;
  color: rgba(248, 250, 252, 0.78);
  font-size: 10px;
  font-weight: 850;
  padding: 7px 9px;
}

.orbit-detail-action {
  background: var(--teal);
  border-color: transparent;
  color: var(--deep);
  display: inline-flex;
  margin-top: 14px;
}

@keyframes center-pulse {
  0%, 100% {
    filter: saturate(1);
    transform: translate(-50%, -50%) scale(1);
  }

  50% {
    filter: saturate(1.35);
    transform: translate(-50%, -50%) scale(1.08);
  }
}

@keyframes sonar-pulse {
  0% {
    opacity: 0.7;
    transform: scale(0.72);
  }

  100% {
    opacity: 0;
    transform: scale(1.45);
  }
}

@keyframes related-pulse {
  0%, 100% {
    opacity: 0.5;
    transform: translate(-50%, -50%) scale(0.86);
  }

  50% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.12);
  }
}

.orbit-notes,
.pillar-grid,
.solution-grid,
.feature-list {
  display: grid;
  gap: 18px;
}

.orbit-notes article,
.pillar-grid article,
.solution-grid article,
.feature-list article,
.resource-block,
.demo-form {
  border-radius: var(--radius-md);
  padding: 26px;
}

.orbit-notes article,
.solution-grid article,
.feature-list article,
.resource-block {
  background: rgba(248, 250, 252, 0.08);
  border: 1px solid rgba(248, 250, 252, 0.12);
  box-shadow: 0 22px 60px rgba(8, 17, 28, 0.18);
}

.orbit-notes span {
  color: var(--teal);
  display: inline-block;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 22px;
}

.orbit-notes p,
.solution-grid p,
.feature-list p,
.resource-block p,
.demo-copy p {
  color: rgba(248, 250, 252, 0.68);
  font-size: 14px;
  font-weight: 600;
  margin: 14px 0 0;
}

.pillars,
.outcomes {
  background: #f7f8f4;
}

.pillar-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 1200px;
  perspective: 1200px;
}

.pillar-grid article {
  background: linear-gradient(145deg, rgba(21, 36, 59, 0.98), rgba(8, 17, 28, 0.94));
  border: 1px solid rgba(248, 250, 252, 0.13);
  box-shadow: 0 24px 62px rgba(8, 17, 28, 0.24);
  color: var(--white);
  min-height: 330px;
  overflow: hidden;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 460ms ease, box-shadow 460ms ease, border-color 460ms ease;
}

.pillar-grid article::before {
  background: linear-gradient(180deg, rgba(248, 250, 252, 0.22), rgba(248, 250, 252, 0.05));
  border: 1px solid rgba(248, 250, 252, 0.18);
  border-radius: 30px;
  content: "";
  inset: 10px;
  opacity: 0.7;
  position: absolute;
  transform: translateZ(24px);
  transition: opacity 300ms ease;
}

.pillar-grid article::after {
  background:
    radial-gradient(circle at 72% 20%, rgba(86, 199, 201, 0.22), transparent 28%),
    linear-gradient(135deg, rgba(86, 199, 201, 0.14), transparent 54%);
  content: "";
  inset: 0;
  opacity: 0.42;
  position: absolute;
  transition: opacity 300ms ease;
}

.pillar-grid article:hover,
.pillar-grid article:focus-within {
  border-color: rgba(86, 199, 201, 0.46);
  box-shadow:
    rgba(8, 17, 28, 0.34) 30px 48px 28px -42px,
    rgba(8, 17, 28, 0.18) 0 24px 34px 0;
  transform: rotate3d(1, -1, 0, 12deg) translateY(-8px);
}

.pillar-grid article:hover::before,
.pillar-grid article:focus-within::before {
  opacity: 1;
}

.pillar-grid article:hover::after,
.pillar-grid article:focus-within::after {
  opacity: 0.72;
}

.pillar-icon {
  align-items: center;
  background: var(--white);
  border-radius: 999px;
  box-shadow: rgba(8, 17, 28, 0.24) -10px 16px 24px 0;
  color: var(--midnight);
  display: inline-flex;
  font-weight: 900;
  height: 52px;
  justify-content: center;
  margin-bottom: 72px;
  position: relative;
  transform: translateZ(92px);
  transition: transform 420ms ease;
  width: 52px;
  z-index: 3;
}

.pillar-grid h3,
.pillar-grid p {
  position: relative;
  transform: translateZ(42px);
  z-index: 3;
}

.pillar-grid p {
  color: rgba(248, 250, 252, 0.68);
  font-size: 14px;
  font-weight: 600;
  margin: 14px 0 0;
}

.card-orbits {
  position: absolute;
  right: 0;
  top: 0;
  transform-style: preserve-3d;
  z-index: 2;
}

.card-orbits i {
  aspect-ratio: 1;
  background: rgba(248, 250, 252, 0.09);
  border-radius: 999px;
  box-shadow: rgba(100, 100, 111, 0.12) -10px 10px 20px 0;
  position: absolute;
  right: 12px;
  top: 12px;
  transition: transform 500ms ease, background 500ms ease;
}

.card-orbits i:nth-child(1) {
  transform: translateZ(18px);
  width: 160px;
}

.card-orbits i:nth-child(2) {
  right: 18px;
  top: 18px;
  transform: translateZ(40px);
  transition-delay: 80ms;
  width: 126px;
}

.card-orbits i:nth-child(3) {
  right: 26px;
  top: 26px;
  transform: translateZ(62px);
  transition-delay: 160ms;
  width: 92px;
}

.card-orbits i:nth-child(4) {
  background: var(--teal);
  right: 36px;
  top: 36px;
  transform: translateZ(86px);
  transition-delay: 240ms;
  width: 46px;
}

.pillar-grid article:hover .card-orbits i,
.pillar-grid article:focus-within .card-orbits i {
  background: rgba(248, 250, 252, 0.16);
  transform: translate3d(-8px, 12px, 98px);
}

.pillar-grid article:hover .card-orbits i:nth-child(4),
.pillar-grid article:focus-within .card-orbits i:nth-child(4) {
  background: var(--sand);
  transform: translate3d(-10px, 16px, 124px);
}

.pillar-grid article:hover .pillar-icon,
.pillar-grid article:focus-within .pillar-icon {
  transform: translate3d(0, 0, 112px) scale(1.06);
}

.platform {
  background:
    radial-gradient(circle at 78% 18%, rgba(86, 199, 201, 0.18), transparent 24rem),
    var(--deep);
  color: var(--white);
}

.split {
  align-items: center;
  display: grid;
  gap: clamp(30px, 5vw, 70px);
  grid-template-columns: minmax(280px, 0.88fr) minmax(340px, 1.12fr);
  margin: 0 auto;
  max-width: 1200px;
}

.split p {
  color: rgba(248, 250, 252, 0.7);
  font-size: 18px;
  font-weight: 600;
  margin: 22px 0 0;
}

.lifecycle {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 28px;
}

.lifecycle span,
.outcome-row span,
.resource-links a {
  border-radius: 999px;
  font-size: 13px;
  font-weight: 850;
  padding: 11px 15px;
}

.lifecycle span {
  background: rgba(248, 250, 252, 0.1);
  border: 1px solid rgba(248, 250, 252, 0.13);
  color: var(--white);
}

.dashboard-visual {
  background: rgba(248, 250, 252, 0.08);
  border: 1px solid rgba(248, 250, 252, 0.12);
  border-radius: var(--radius-lg);
  box-shadow: var(--hard-shadow);
  padding: 18px;
}

.dash-top {
  align-items: center;
  border-bottom: 1px solid rgba(248, 250, 252, 0.1);
  display: flex;
  gap: 8px;
  padding-bottom: 16px;
}

.dash-top span {
  background: rgba(248, 250, 252, 0.28);
  border-radius: 999px;
  height: 11px;
  width: 11px;
}

.dash-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding-top: 16px;
}

.dash-panel {
  background: rgba(21, 36, 59, 0.72);
  border: 1px solid rgba(248, 250, 252, 0.09);
  border-radius: 22px;
  min-height: 150px;
  padding: 20px;
}

.dash-panel.wide {
  grid-column: span 2;
  min-height: 190px;
}

.dash-panel strong {
  color: rgba(248, 250, 252, 0.8);
  display: block;
  font-size: 12px;
  font-weight: 850;
  margin-bottom: 16px;
  text-transform: uppercase;
}

.dash-panel em {
  color: var(--teal);
  font-size: 48px;
  font-style: normal;
  font-weight: 900;
}

.assurance-gauge {
  align-items: end;
  background: conic-gradient(from 270deg, var(--teal) 0 74%, rgba(248, 250, 252, 0.14) 74% 100%);
  border-radius: 50%;
  display: flex;
  height: 122px;
  justify-content: center;
  margin: 0 auto;
  width: 122px;
}

.assurance-gauge span {
  background: var(--midnight);
  border-radius: 50%;
  height: 78px;
  margin-bottom: 22px;
  width: 78px;
}

.chart {
  align-items: end;
  display: grid;
  gap: 9px;
  grid-template-columns: repeat(5, 1fr);
}

.chart strong,
.matrix strong {
  grid-column: 1 / -1;
}

.chart i {
  background: linear-gradient(180deg, var(--teal), var(--ocean));
  border-radius: 999px 999px 4px 4px;
  display: block;
  min-height: 30px;
}

.matrix {
  display: grid;
  gap: 7px;
  grid-template-columns: repeat(3, 1fr);
}

.matrix span {
  aspect-ratio: 1;
  background: rgba(86, 199, 201, 0.14);
  border: 1px solid rgba(86, 199, 201, 0.26);
  border-radius: 10px;
}

.matrix span:nth-of-type(5),
.matrix span:nth-of-type(9) {
  background: rgba(230, 213, 182, 0.72);
}

.solution-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 1200px;
  perspective: 1000px;
}

.solution-grid article {
  min-height: 250px;
  overflow: hidden;
  position: relative;
  transform-style: preserve-3d;
  transition: transform 360ms ease, border-color 360ms ease, box-shadow 360ms ease;
}

.solution-grid article::before,
.feature-list article::before,
.resource-block::before {
  aspect-ratio: 1;
  background:
    radial-gradient(circle at 32% 28%, rgba(248, 250, 252, 0.18), rgba(248, 250, 252, 0.04) 52%, rgba(86, 199, 201, 0.08) 100%);
  border-radius: 999px;
  content: "";
  position: absolute;
  right: -34px;
  top: -34px;
  transform: translateZ(24px);
  transition: transform 360ms ease, opacity 360ms ease;
  width: 132px;
}

.solution-grid article::after,
.feature-list article::after,
.resource-block::after {
  aspect-ratio: 1;
  background: rgba(86, 199, 201, 0.22);
  border-radius: 999px;
  content: "";
  position: absolute;
  right: 24px;
  top: 24px;
  transform: translateZ(54px);
  transition: transform 360ms ease, background 360ms ease;
  width: 34px;
}

.solution-grid article h3,
.solution-grid article p,
.feature-list article h3,
.feature-list article p,
.resource-block > * {
  position: relative;
  z-index: 2;
}

.solution-grid article:hover,
.solution-grid article:focus-within {
  border-color: rgba(86, 199, 201, 0.42);
  box-shadow: 0 28px 80px rgba(8, 17, 28, 0.28);
  transform: rotate3d(0.7, -0.8, 0, 8deg) translateY(-6px);
}

.solution-grid article:hover::before,
.solution-grid article:focus-within::before,
.feature-list article:hover::before,
.feature-list article:focus-within::before,
.resource-block:hover::before,
.resource-block:focus-within::before {
  transform: translate3d(-10px, 12px, 72px);
}

.solution-grid article:hover::after,
.solution-grid article:focus-within::after,
.feature-list article:hover::after,
.feature-list article:focus-within::after,
.resource-block:hover::after,
.resource-block:focus-within::after {
  background: var(--sand);
  transform: translate3d(-12px, 14px, 92px);
}

.solution-schema {
  background:
    radial-gradient(circle at 68% 36%, rgba(86, 199, 201, 0.14), transparent 24rem),
    linear-gradient(180deg, #050b13 0%, #08111c 100%);
  isolation: isolate;
  overflow: hidden;
  position: relative;
}

.solution-schema::before {
  background:
    radial-gradient(circle at 18% 20%, rgba(86, 199, 201, 0.14), transparent 22rem),
    radial-gradient(circle at 78% 48%, rgba(31, 78, 121, 0.2), transparent 26rem);
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: -1;
}

.solution-schema .section-heading,
.solution-spotlight,
.solution-tabs {
  position: relative;
  z-index: 1;
}

.solution-spotlight {
  align-items: center;
  background: rgba(248, 250, 252, 0.04);
  border: 1px solid rgba(248, 250, 252, 0.1);
  border-radius: 30px;
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.26);
  display: grid;
  gap: clamp(28px, 5vw, 72px);
  grid-template-columns: minmax(280px, 0.92fr) minmax(320px, 1.08fr);
  margin: 0 auto;
  max-width: 1160px;
  overflow: hidden;
  padding: clamp(28px, 5vw, 54px);
}

.solution-spotlight-copy {
  animation: spotlight-in 680ms ease both;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.spotlight-preheader {
  align-items: center;
  color: rgba(248, 250, 252, 0.7);
  display: flex;
  font-size: 13px;
  font-weight: 850;
  gap: 10px;
}

.spotlight-preheader span {
  background: var(--teal);
  border-radius: 999px;
  box-shadow: 0 0 28px rgba(86, 199, 201, 0.5);
  height: 10px;
  width: 10px;
}

.solution-spotlight h3 {
  color: var(--white);
  font-size: clamp(32px, 4vw, 52px);
}

.solution-spotlight p {
  color: rgba(248, 250, 252, 0.68);
  font-size: 17px;
  font-weight: 600;
  margin: 0;
}

.spotlight-button {
  align-self: flex-start;
  background: var(--teal);
  border-radius: 999px;
  color: var(--deep);
  font-size: 14px;
  font-weight: 900;
  padding: 13px 18px;
}

.solution-spotlight-visual {
  animation: spotlight-zoom 720ms 160ms ease both;
  min-height: 360px;
  position: relative;
}

.fleet-map {
  background:
    linear-gradient(90deg, rgba(248, 250, 252, 0.08) 1px, transparent 1px),
    linear-gradient(rgba(248, 250, 252, 0.08) 1px, transparent 1px),
    radial-gradient(circle at 50% 50%, rgba(86, 199, 201, 0.2), rgba(8, 17, 28, 0.32));
  background-size: 26px 26px, 26px 26px, auto;
  border: 1px solid rgba(86, 199, 201, 0.22);
  border-radius: 28px;
  inset: 30px 0;
  overflow: hidden;
  position: absolute;
}

.fleet-map i {
  background: linear-gradient(90deg, transparent, rgba(86, 199, 201, 0.7), transparent);
  height: 2px;
  left: 12%;
  position: absolute;
  top: 50%;
  transform-origin: left center;
  width: 76%;
}

.fleet-map i:nth-child(1) {
  transform: rotate(18deg);
}

.fleet-map i:nth-child(2) {
  transform: rotate(-18deg);
}

.fleet-map i:nth-child(3) {
  transform: rotate(0deg);
}

.fleet-card {
  animation: spotlight-float 5.5s ease-in-out infinite;
  background: rgba(248, 250, 252, 0.88);
  border: 1px solid rgba(248, 250, 252, 0.5);
  border-radius: 22px;
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.22);
  color: var(--midnight);
  min-width: 156px;
  padding: 18px;
  position: absolute;
  z-index: 2;
}

.fleet-card span {
  color: rgba(47, 52, 72, 0.68);
  display: block;
  font-size: 11px;
  font-weight: 850;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.fleet-card strong {
  color: var(--ocean);
  font-size: 34px;
  font-weight: 900;
}

.float-one {
  left: 4%;
  top: 10%;
}

.float-two {
  animation-delay: -1.8s;
  right: 4%;
  top: 28%;
}

.float-three {
  animation-delay: -3.2s;
  bottom: 8%;
  left: 24%;
}

.solution-tabs {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  margin: 22px auto 0;
  max-width: 1160px;
}

.solution-tabs a {
  background: rgba(248, 250, 252, 0.06);
  border: 1px solid rgba(248, 250, 252, 0.1);
  border-radius: 18px;
  color: var(--white);
  padding: 16px;
  transition: background 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.solution-tabs a:hover,
.solution-tabs a:focus-visible {
  background: rgba(86, 199, 201, 0.12);
  border-color: rgba(86, 199, 201, 0.38);
  transform: translateY(-3px);
}

.solution-tabs span {
  color: var(--teal);
  display: block;
  font-size: 11px;
  font-weight: 850;
  margin-bottom: 5px;
  text-transform: uppercase;
}

.solution-tabs strong {
  font-size: 15px;
}

@keyframes spotlight-in {
  from {
    opacity: 0;
    transform: translateY(22px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes spotlight-zoom {
  from {
    opacity: 0;
    transform: scale(0.96);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes spotlight-float {
  0%, 100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-12px);
  }
}

.features {
  border-top: 1px solid rgba(248, 250, 252, 0.1);
}

.feature-list {
  align-items: stretch;
  display: grid;
  gap: 16px;
  grid-auto-flow: dense;
  grid-auto-rows: minmax(150px, auto);
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin: 0 auto;
  max-width: 1200px;
  perspective: 1000px;
}

.feature-list article {
  background:
    linear-gradient(145deg, rgba(17, 43, 69, 0.94), rgba(8, 17, 28, 0.86)),
    radial-gradient(circle at 86% 18%, rgba(86, 199, 201, 0.2), transparent 9rem);
  border: 1px solid rgba(248, 250, 252, 0.12);
  box-shadow: 0 18px 46px rgba(8, 17, 28, 0.2);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 180px;
  overflow: hidden;
  padding: 24px;
  position: relative;
  scroll-margin-top: 110px;
  transition: transform 300ms ease, border-color 300ms ease, box-shadow 300ms ease, background 300ms ease;
}

.feature-list article::before {
  background:
    linear-gradient(90deg, rgba(86, 199, 201, 0.7), transparent),
    repeating-linear-gradient(90deg, rgba(248, 250, 252, 0.16) 0 1px, transparent 1px 22px);
  border-radius: 0;
  bottom: 18px;
  content: "";
  height: 3px;
  left: 24px;
  opacity: 0.68;
  position: absolute;
  right: 24px;
  top: auto;
  transform: none;
  transition: opacity 300ms ease, transform 300ms ease;
  width: auto;
}

.feature-list article::after {
  background:
    radial-gradient(circle, rgba(86, 199, 201, 0.84) 0 30%, rgba(86, 199, 201, 0.16) 31% 100%);
  border: 1px solid rgba(248, 250, 252, 0.2);
  border-radius: 999px;
  content: "";
  height: 42px;
  position: absolute;
  right: 22px;
  top: 22px;
  transform: none;
  transition: transform 300ms ease, opacity 300ms ease;
  width: 42px;
}

.feature-list article:nth-child(1) {
  background:
    radial-gradient(circle at 82% 18%, rgba(86, 199, 201, 0.28), transparent 12rem),
    linear-gradient(145deg, rgba(231, 240, 250, 0.96), rgba(179, 208, 237, 0.9) 42%, rgba(22, 60, 96, 0.94));
  color: var(--midnight);
  grid-column: span 3;
  grid-row: span 2;
  min-height: 386px;
  padding: 30px;
}

.feature-list article:nth-child(2),
.feature-list article:nth-child(6),
.feature-list article:nth-child(11) {
  grid-column: span 3;
}

.feature-list article:nth-child(3),
.feature-list article:nth-child(4),
.feature-list article:nth-child(5),
.feature-list article:nth-child(8),
.feature-list article:nth-child(9),
.feature-list article:nth-child(10),
.feature-list article:nth-child(12),
.feature-list article:nth-child(13),
.feature-list article:nth-child(14) {
  grid-column: span 2;
}

.feature-list article:nth-child(7) {
  background:
    linear-gradient(135deg, rgba(86, 199, 201, 0.92), rgba(31, 78, 121, 0.9)),
    radial-gradient(circle at 78% 20%, rgba(248, 250, 252, 0.32), transparent 9rem);
  color: var(--midnight);
  grid-column: span 3;
}

.feature-list article:nth-child(1)::after,
.feature-list article:nth-child(7)::after {
  background: rgba(248, 250, 252, 0.58);
  height: 86px;
  opacity: 0.58;
  right: -20px;
  top: -20px;
  width: 86px;
}

.feature-list article:nth-child(1) h3,
.feature-list article:nth-child(7) h3 {
  color: var(--midnight);
}

.feature-list article:nth-child(1) p,
.feature-list article:nth-child(7) p {
  color: rgba(21, 36, 59, 0.74);
}

.feature-list article h3 {
  font-size: clamp(22px, 2.4vw, 34px);
  line-height: 1.08;
  max-width: 84%;
}

.feature-list article p {
  font-size: 13px;
  line-height: 1.55;
  margin-top: 18px;
  max-width: 92%;
}

.feature-list article:nth-child(1) h3 {
  font-size: clamp(34px, 4vw, 54px);
  max-width: 76%;
}

.feature-list article:nth-child(1) p {
  font-size: 16px;
  max-width: 74%;
}

.feature-list article:hover::before,
.feature-list article:focus-within::before {
  opacity: 1;
  transform: translateY(-4px);
}

.feature-list article:hover::after,
.feature-list article:focus-within::after {
  opacity: 0.92;
  transform: scale(1.08);
}

.feature-list article:hover,
.feature-list article:focus-within,
.resource-block:hover,
.resource-block:focus-within {
  border-color: rgba(86, 199, 201, 0.34);
  box-shadow: 0 24px 70px rgba(8, 17, 28, 0.24);
  transform: translateY(-5px);
}

.feature-list article:target {
  border-color: rgba(86, 199, 201, 0.72);
  box-shadow: 0 24px 80px rgba(86, 199, 201, 0.18);
}

.outcome-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin: 0 auto;
  max-width: 1080px;
}

.outcome-row span,
.resource-links a {
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(21, 36, 59, 0.1);
  color: var(--midnight);
  box-shadow: 0 14px 36px rgba(8, 17, 28, 0.06);
}

.resources-about {
  background:
    linear-gradient(180deg, #f7f8f4 0%, #eef3f3 100%);
  color: var(--midnight);
  display: grid;
  gap: 0;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  padding-top: clamp(72px, 8vw, 110px);
  padding-bottom: clamp(72px, 8vw, 110px);
  position: relative;
}

.resources-about::before {
  background:
    linear-gradient(90deg, rgba(31, 78, 121, 0.12) 1px, transparent 1px),
    linear-gradient(rgba(31, 78, 121, 0.08) 1px, transparent 1px);
  background-size: 42px 42px;
  content: "";
  inset: 0;
  opacity: 0.36;
  pointer-events: none;
  position: absolute;
}

.resource-block {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
  padding: 0 clamp(22px, 4vw, 54px);
  position: relative;
  transition: none;
}

.resource-block::before,
.resource-block::after {
  content: none;
}

.resource-block:first-child {
  border-right: 1px solid rgba(21, 36, 59, 0.16);
}

.resource-block .eyebrow {
  color: rgba(31, 78, 121, 0.74);
  letter-spacing: 0.16em;
}

.resource-block h2 {
  border-bottom: 2px solid rgba(21, 36, 59, 0.14);
  color: var(--midnight);
  font-size: clamp(34px, 5vw, 68px);
  margin-bottom: 28px;
  padding-bottom: 28px;
}

.resource-block p {
  color: rgba(21, 36, 59, 0.72);
  font-size: 18px;
  line-height: 1.7;
  margin-top: 0;
}

.resource-links {
  display: grid;
  gap: 0;
  margin-top: 14px;
}

.resource-links a {
  align-items: center;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(21, 36, 59, 0.14);
  border-radius: 0;
  box-shadow: none;
  color: var(--midnight);
  display: grid;
  font-size: clamp(18px, 2vw, 26px);
  font-weight: 850;
  gap: 18px;
  grid-template-columns: 82px 1fr auto;
  padding: 18px 0;
  transition: color 180ms ease, padding 180ms ease;
}

.resource-links a::after {
  color: rgba(31, 78, 121, 0.55);
  content: "↗";
  font-size: 16px;
}

.resource-links a span {
  color: rgba(31, 78, 121, 0.62);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.resource-links a:hover,
.resource-links a:focus-visible {
  color: var(--ocean);
  padding-left: 10px;
}

#about::after {
  content: none;
}

.about-stripes {
  display: grid;
  align-content: start;
}

.about-stripes h2 {
  font-size: clamp(34px, 4.5vw, 58px);
}

.about-stripes > p {
  max-width: 780px;
  color: rgba(21, 36, 59, 0.74);
  font-size: clamp(17px, 1.45vw, 20px);
  font-weight: 700;
  line-height: 1.6;
}

.about-proof-grid {
  display: grid;
  gap: 12px;
  margin-top: 30px;
}

.about-proof-grid article {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 4px 18px;
  align-items: start;
  padding: 20px 0;
  border-bottom: 1px solid rgba(21, 36, 59, 0.14);
}

.about-proof-grid article:first-child {
  border-top: 1px solid rgba(21, 36, 59, 0.14);
}

.about-proof-grid span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  color: var(--midnight);
  background: rgba(89, 204, 214, 0.28);
  border: 1px solid rgba(31, 78, 121, 0.18);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  font-weight: 950;
}

.about-proof-grid strong {
  color: var(--midnight);
  font-size: clamp(20px, 2vw, 27px);
  line-height: 1.08;
}

.about-proof-grid p {
  margin: 0;
  color: rgba(21, 36, 59, 0.66);
  font-size: 15px;
  font-weight: 750;
  line-height: 1.48;
}

.about-signal {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 28px;
}

.about-signal span {
  padding: 10px 14px;
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 999px;
  color: var(--midnight);
  background: rgba(255, 255, 255, 0.58);
  box-shadow: 0 12px 34px rgba(31, 78, 121, 0.08);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.demo {
  align-items: start;
  background:
    radial-gradient(circle at 16% 16%, rgba(86, 199, 201, 0.18), transparent 22rem),
    var(--deep);
  color: var(--white);
  display: grid;
  gap: clamp(30px, 5vw, 70px);
  grid-template-columns: minmax(280px, 0.9fr) minmax(320px, 1.1fr);
}

.demo-copy p {
  color: rgba(248, 250, 252, 0.72);
  font-size: 18px;
  font-weight: 600;
}

.demo-form {
  background: rgba(248, 250, 252, 0.08);
  border: 1px solid rgba(248, 250, 252, 0.13);
  box-shadow: var(--hard-shadow);
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.demo-form label {
  color: rgba(248, 250, 252, 0.82);
  display: grid;
  font-size: 12px;
  font-weight: 850;
  gap: 8px;
  text-transform: uppercase;
}

.demo-form input {
  background: rgba(8, 17, 28, 0.36);
  border: 1px solid rgba(248, 250, 252, 0.13);
  border-radius: 999px;
  color: var(--white);
  font: inherit;
  min-height: 48px;
  padding: 10px 16px;
}

.demo-form input:focus {
  border-color: var(--teal);
  outline: 3px solid rgba(86, 199, 201, 0.18);
}

.demo-form button {
  border: 0;
  cursor: pointer;
  grid-column: 1 / -1;
}

.site-footer {
  align-items: start;
  background: var(--midnight);
  color: var(--white);
  display: flex;
  gap: 24px;
  justify-content: space-between;
  padding: 38px clamp(20px, 6vw, 86px);
}

.site-footer strong {
  font-size: 20px;
  font-weight: 900;
}

.site-footer p {
  color: rgba(248, 250, 252, 0.68);
  font-size: 13px;
  font-weight: 600;
  margin: 8px 0 0;
}

.site-footer nav {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 22px;
  justify-content: flex-end;
}

.site-footer a {
  color: rgba(248, 250, 252, 0.78);
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 1100px) {
  .desktop-nav {
    display: none;
  }

  .menu-toggle {
    display: flex;
  }
}

@media (max-width: 980px) {
  .hero,
  .orbit-layout,
  .split,
  .demo,
  .resources-about {
    grid-template-columns: 1fr;
  }

  .resource-block:first-child {
    border-bottom: 1px solid rgba(21, 36, 59, 0.16);
    border-right: 0;
    padding-bottom: 38px;
  }

  .resource-block:last-child {
    padding-top: 38px;
  }

  .testimonial {
    background:
      linear-gradient(rgba(247, 248, 244, 0.93), rgba(247, 248, 244, 0.93)),
      url("./hero-maritime-intelligence.png") center / cover;
  }

  .testimonial-inner {
    grid-template-columns: 1fr;
  }

  .testimonial-rail {
    max-width: 260px;
  }

  .testimonial-seal {
    justify-self: start;
    width: 138px;
  }

  .hero {
    min-height: auto;
  }

  .hero-media-card {
    min-height: 460px;
  }

  .pillar-grid,
  .solution-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .feature-list {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .feature-list article,
  .feature-list article:nth-child(2),
  .feature-list article:nth-child(3),
  .feature-list article:nth-child(4),
  .feature-list article:nth-child(5),
  .feature-list article:nth-child(6),
  .feature-list article:nth-child(8),
  .feature-list article:nth-child(9),
  .feature-list article:nth-child(10),
  .feature-list article:nth-child(11),
  .feature-list article:nth-child(12),
  .feature-list article:nth-child(13),
  .feature-list article:nth-child(14) {
    grid-column: span 2;
  }

  .feature-list article:nth-child(1),
  .feature-list article:nth-child(7) {
    grid-column: span 4;
  }
}

@media (max-width: 660px) {
  .testimonial blockquote > p {
    font-size: 28px;
    line-height: 1.16;
  }

  .testimonial footer {
    grid-template-columns: 1fr;
  }

  .testimonial-seal {
    width: 116px;
  }

  .site-header {
    border-radius: 26px;
    left: 10px;
    padding: 9px 10px 9px 12px;
    right: 10px;
    top: 10px;
  }

  .brand small {
    display: none;
  }

  .brand strong {
    font-size: 16px;
  }

  .nav-cta {
    display: none;
  }

  .hero {
    gap: 24px;
    grid-template-areas: "stack";
    padding: 90px 14px 28px;
  }

  .hero::before {
    display: none;
  }

  .hero-content,
  .hero-media-card {
    grid-area: stack;
  }

  .hero-content {
    align-self: end;
    color: var(--white);
    padding: 0 18px 34px;
    z-index: 4;
  }

  .slide-count {
    color: rgba(248, 250, 252, 0.7);
  }

  .hero .eyebrow {
    color: var(--teal);
  }

  h1 {
    font-size: 32px;
  }

  h2 {
    font-size: 32px;
  }

  .hero-copy {
    color: rgba(248, 250, 252, 0.82);
    font-size: 15px;
  }

  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .hero-metrics {
    display: none;
  }

  .hero-media-card {
    border-radius: 26px;
    height: 700px;
    min-height: 0;
  }

  .flow-lines {
    inset: 0;
    overflow: hidden;
  }

  .flow-lines span {
    left: 0;
    width: 100%;
  }

  .hero-arrow {
    height: 44px;
    width: 44px;
  }

  .section {
    padding-left: 14px;
    padding-right: 14px;
  }

  .orbit-stage {
    border-radius: 26px;
    min-height: 0;
    width: 100%;
  }

  .orbit-core {
    height: 140px;
    width: 140px;
  }

  .orbit-core strong {
    font-size: 18px;
  }

  .orbit-track-one {
    --orbit-radius: 128px;
  }

  .orbit-track-two {
    --orbit-radius: 160px;
  }

  .orbit-track-three {
    --orbit-radius: 92px;
  }

  .orbit-logo {
    height: 46px;
    width: 46px;
  }

  .logo-mark {
    border-radius: 14px;
    height: 28px;
    transform: scale(0.82);
    width: 28px;
  }

  .pillar-grid,
  .solution-grid,
  .feature-list,
  .demo-form,
  .dash-grid {
    grid-template-columns: 1fr;
  }

  .feature-list article,
  .feature-list article:nth-child(1),
  .feature-list article:nth-child(2),
  .feature-list article:nth-child(3),
  .feature-list article:nth-child(4),
  .feature-list article:nth-child(5),
  .feature-list article:nth-child(6),
  .feature-list article:nth-child(7),
  .feature-list article:nth-child(8),
  .feature-list article:nth-child(9),
  .feature-list article:nth-child(10),
  .feature-list article:nth-child(11),
  .feature-list article:nth-child(12),
  .feature-list article:nth-child(13),
  .feature-list article:nth-child(14) {
    grid-column: auto;
    grid-row: auto;
    min-height: auto;
  }

  .feature-list article:nth-child(1) h3,
  .feature-list article h3 {
    font-size: 27px;
    max-width: 82%;
  }

  .feature-list article:nth-child(1) p,
  .feature-list article p {
    font-size: 14px;
    max-width: 100%;
  }

  .pillar-grid article {
    min-height: auto;
  }

  .pillar-icon {
    margin-bottom: 42px;
  }

  .dash-panel.wide {
    grid-column: auto;
  }

  .site-footer {
    display: grid;
  }

  .site-footer nav {
    justify-content: start;
  }
}

/* Stripes Marine testimonial carousel */
.testimonial-carousel {
  background: #f7f8f4;
  color: var(--midnight);
  overflow: hidden;
  position: relative;
}

.testimonial-carousel::before {
  background:
    radial-gradient(circle at 14% 20%, rgba(86, 199, 201, 0.16), transparent 20rem),
    linear-gradient(90deg, rgba(31, 78, 121, 0.08) 1px, transparent 1px),
    linear-gradient(rgba(31, 78, 121, 0.06) 1px, transparent 1px);
  background-size: auto, 44px 44px, 44px 44px;
  content: "";
  inset: 0;
  opacity: 0.9;
  pointer-events: none;
  position: absolute;
}

.testimonial-container {
  align-items: center;
  display: grid;
  gap: clamp(42px, 7vw, 92px);
  grid-template-columns: minmax(280px, 0.95fr) minmax(320px, 1.05fr);
  margin: 0 auto;
  max-width: 1120px;
  position: relative;
}

.testimonial-image-stage {
  height: clamp(330px, 40vw, 470px);
  perspective: 1000px;
  position: relative;
}

.testimonial-image {
  border-radius: 26px;
  box-shadow: 0 28px 70px rgba(8, 17, 28, 0.24);
  height: 100%;
  left: 50%;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  transform: translateX(-50%) scale(0.82);
  transition: transform 760ms cubic-bezier(.4, 1.7, .3, 1), opacity 520ms ease, filter 520ms ease;
  width: min(78%, 350px);
}

.testimonial-image.is-active {
  filter: none;
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0) scale(1) rotateY(0deg);
  z-index: 3;
}

.testimonial-image.is-left {
  filter: saturate(0.82) contrast(0.94);
  opacity: 0.82;
  transform: translateX(calc(-50% - 72px)) translateY(-42px) scale(0.84) rotateY(15deg);
  z-index: 2;
}

.testimonial-image.is-right {
  filter: saturate(0.82) contrast(0.94);
  opacity: 0.82;
  transform: translateX(calc(-50% + 72px)) translateY(-42px) scale(0.84) rotateY(-15deg);
  z-index: 2;
}

.testimonial-content {
  min-height: 420px;
  position: relative;
}

.testimonial-content.is-transitioning [data-testimonial-name],
.testimonial-content.is-transitioning [data-testimonial-role],
.testimonial-content.is-transitioning [data-testimonial-quote] {
  opacity: 0;
  transform: translateY(12px);
}

.testimonial-content .eyebrow {
  color: rgba(31, 78, 121, 0.74);
  margin-bottom: 22px;
}

.testimonial-content h2 {
  color: var(--midnight);
  font-size: clamp(34px, 5vw, 62px);
  margin: 0;
}

.testimonial-role {
  color: rgba(21, 36, 59, 0.58);
  font-size: 14px;
  font-weight: 850;
  letter-spacing: 0.08em;
  margin: 8px 0 34px;
  text-transform: uppercase;
}

.testimonial-content blockquote {
  margin: 0;
}

.testimonial-content blockquote p {
  color: rgba(21, 36, 59, 0.74);
  font-size: clamp(18px, 2.1vw, 25px);
  font-weight: 650;
  line-height: 1.72;
  margin: 0;
}

.testimonial-content blockquote p::before {
  color: var(--teal);
  content: "“";
  font-size: 2.6em;
  font-weight: 900;
  line-height: 0;
  margin-left: -0.18em;
  vertical-align: -0.34em;
}

.testimonial-controls {
  align-items: center;
  display: flex;
  gap: 14px;
  margin-top: 42px;
}

.testimonial-arrow {
  align-items: center;
  background: var(--midnight);
  border: 0;
  border-radius: 999px;
  color: var(--white);
  display: inline-flex;
  font-size: 31px;
  font-weight: 700;
  height: 48px;
  justify-content: center;
  line-height: 1;
  transition: background 180ms ease, transform 180ms ease;
  width: 48px;
}

.testimonial-arrow:hover,
.testimonial-arrow:focus-visible {
  background: var(--teal);
  color: var(--deep);
  transform: translateY(-2px);
}

.testimonial-dots {
  display: inline-flex;
  gap: 8px;
  margin-left: 8px;
}

.testimonial-dots span {
  background: rgba(31, 78, 121, 0.22);
  border-radius: 999px;
  height: 8px;
  transition: background 200ms ease, width 200ms ease;
  width: 8px;
}

.testimonial-dots span.is-active {
  background: var(--teal);
  width: 32px;
}

[data-testimonial-name],
[data-testimonial-role],
[data-testimonial-quote] {
  transition: opacity 220ms ease, transform 220ms ease;
}

@media (max-width: 900px) {
  .testimonial-container {
    grid-template-columns: 1fr;
  }

  .testimonial-content {
    min-height: 0;
  }
}

@media (max-width: 660px) {
  .testimonial-image-stage {
    height: 330px;
  }

  .testimonial-image {
    width: min(82%, 310px);
  }

  .testimonial-image.is-left {
    transform: translateX(calc(-50% - 48px)) translateY(-28px) scale(0.8) rotateY(14deg);
  }

  .testimonial-image.is-right {
    transform: translateX(calc(-50% + 48px)) translateY(-28px) scale(0.8) rotateY(-14deg);
  }

  .testimonial-content h2 {
    font-size: 34px;
  }

  .testimonial-content blockquote p {
    font-size: 17px;
  }
}


/* Platform page */
.platform-page {
  background: #f7f8f4;
  color: var(--midnight);
}

.platform-hero {
  align-items: center;
  background:
    radial-gradient(circle at 10% 18%, rgba(86, 199, 201, 0.18), transparent 26rem),
    linear-gradient(120deg, #f7f8f4 0 54%, rgba(31, 78, 121, 0.14) 54% 100%);
  display: grid;
  gap: clamp(38px, 6vw, 82px);
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1.05fr);
  min-height: 100vh;
  overflow: hidden;
  padding: clamp(128px, 13vw, 170px) clamp(22px, 5vw, 72px) clamp(72px, 8vw, 110px);
  position: relative;
}

.platform-hero::before {
  background:
    linear-gradient(90deg, rgba(31, 78, 121, 0.08) 1px, transparent 1px),
    linear-gradient(rgba(31, 78, 121, 0.06) 1px, transparent 1px);
  background-size: 46px 46px;
  content: "";
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.platform-hero-copy,
.platform-command {
  position: relative;
}

.platform-hero h1 {
  color: var(--midnight);
  font-size: clamp(48px, 7vw, 94px);
  line-height: 0.96;
  margin: 0;
  max-width: 760px;
}

.platform-hero-copy > p:not(.eyebrow) {
  color: rgba(21, 36, 59, 0.68);
  font-size: clamp(18px, 2vw, 23px);
  font-weight: 650;
  line-height: 1.55;
  margin: 28px 0 0;
  max-width: 720px;
}

.platform-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 34px;
}

.platform-command {
  background:
    linear-gradient(145deg, rgba(8, 17, 28, 0.96), rgba(17, 43, 69, 0.94)),
    url("./hero-fleet-analytics-room.png") center / cover;
  border: 1px solid rgba(248, 250, 252, 0.16);
  border-radius: 30px;
  box-shadow: 0 42px 100px rgba(8, 17, 28, 0.26);
  color: var(--white);
  min-height: 560px;
  overflow: hidden;
  padding: clamp(24px, 4vw, 42px);
}

.platform-command::before {
  background: linear-gradient(rgba(8, 17, 28, 0.28), rgba(8, 17, 28, 0.82));
  content: "";
  inset: 0;
  position: absolute;
}

.command-topline,
.command-grid {
  position: relative;
}

.command-topline {
  align-items: center;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 26px;
}

.command-topline span,
.command-panel span {
  color: rgba(248, 250, 252, 0.62);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.command-topline strong {
  color: var(--teal);
  font-size: 13px;
  text-transform: uppercase;
}

.command-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.command-panel {
  background: rgba(248, 250, 252, 0.1);
  border: 1px solid rgba(248, 250, 252, 0.14);
  border-radius: 18px;
  min-height: 132px;
  padding: 20px;
}

.command-panel.wide { grid-column: span 2; }
.command-panel.tall { grid-column: span 2; grid-row: span 2; }
.command-panel.muted { grid-column: span 4; }

.command-panel strong {
  color: var(--white);
  display: block;
  font-size: clamp(26px, 4vw, 48px);
  margin-top: 12px;
}

.command-panel.muted strong {
  font-size: 22px;
}

.command-bar {
  background: rgba(248, 250, 252, 0.14);
  border-radius: 999px;
  height: 8px;
  margin-top: 28px;
  overflow: hidden;
}

.command-bar i {
  background: linear-gradient(90deg, var(--teal), var(--sand));
  display: block;
  height: 100%;
}

.mini-radar {
  align-items: center;
  aspect-ratio: 1;
  background: repeating-radial-gradient(circle, rgba(86, 199, 201, 0.28) 0 1px, transparent 1px 32px);
  border-radius: 999px;
  display: grid;
  justify-items: center;
  margin: 22px auto 0;
  max-width: 220px;
  position: relative;
}

.mini-radar i {
  background: rgba(86, 199, 201, 0.42);
  border-radius: 999px;
  height: 14px;
  position: absolute;
  width: 14px;
}

.mini-radar i:nth-child(1) { transform: translate(54px, -34px); }
.mini-radar i:nth-child(2) { transform: translate(-48px, 24px); }
.mini-radar i:nth-child(3) { transform: translate(8px, 62px); }

.platform-subnav {
  backdrop-filter: blur(18px);
  background: rgba(247, 248, 244, 0.86);
  border-bottom: 1px solid rgba(21, 36, 59, 0.1);
  border-top: 1px solid rgba(21, 36, 59, 0.08);
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 12px clamp(22px, 5vw, 72px);
  position: sticky;
  top: 0;
  z-index: 20;
}

.platform-subnav a {
  border: 1px solid rgba(21, 36, 59, 0.12);
  border-radius: 999px;
  color: rgba(21, 36, 59, 0.72);
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 900;
  padding: 10px 14px;
  text-transform: uppercase;
}

.platform-subnav a:hover,
.platform-subnav a:focus-visible {
  background: var(--midnight);
  color: var(--white);
}

.platform-section {
  padding: clamp(72px, 8vw, 118px) clamp(22px, 5vw, 72px);
  scroll-margin-top: 96px;
}

.platform-section-heading {
  margin: 0 auto clamp(34px, 5vw, 60px);
  max-width: 1120px;
}

.platform-section-heading h2,
.platform-cta h2 {
  color: var(--midnight);
  font-size: clamp(36px, 5.4vw, 72px);
  line-height: 1.02;
  margin: 0;
  max-width: 980px;
}

.split-heading {
  align-items: end;
  display: grid;
  gap: 24px;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.48fr);
}

.split-heading > p {
  color: rgba(21, 36, 59, 0.66);
  font-size: 17px;
  font-weight: 650;
  line-height: 1.65;
  margin: 0;
}

.platform-overview-grid,
.module-board,
.governance-grid {
  margin: 0 auto;
  max-width: 1120px;
}

.platform-overview-grid {
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  overflow: hidden;
}

.platform-overview-grid article {
  background: var(--white);
  border-top: 3px solid var(--teal);
  padding: 30px;
}

.platform-overview-grid span {
  color: var(--ocean);
  font-size: 13px;
  font-weight: 950;
}

.platform-overview-grid h3,
.module-card h3,
.model-steps h3 {
  color: var(--midnight);
  font-size: 24px;
  line-height: 1.14;
  margin: 18px 0 0;
}

.platform-overview-grid p,
.module-card p {
  color: rgba(21, 36, 59, 0.64);
  font-size: 15px;
  font-weight: 650;
  line-height: 1.62;
  margin: 18px 0 0;
}

.modules-section {
  background: var(--deep);
  color: var(--white);
}

.modules-section .platform-section-heading h2,
.modules-section .module-card h3 {
  color: var(--white);
}

.modules-section .split-heading > p,
.modules-section .module-card p {
  color: rgba(248, 250, 252, 0.66);
}

.module-board {
  display: grid;
  gap: 16px;
  grid-auto-flow: dense;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.module-card {
  background: rgba(248, 250, 252, 0.08);
  border: 1px solid rgba(248, 250, 252, 0.12);
  min-height: 260px;
  padding: 28px;
  position: relative;
}

.module-card.primary {
  background: linear-gradient(145deg, rgba(248, 250, 252, 0.96), rgba(179, 208, 237, 0.88));
  color: var(--midnight);
  grid-column: span 3;
  grid-row: span 2;
}

.module-card.primary h3,
.module-card.primary p { color: var(--midnight); }
.module-card.accent { background: linear-gradient(135deg, rgba(86, 199, 201, 0.9), rgba(31, 78, 121, 0.86)); grid-column: span 3; }
.module-card:not(.primary):not(.accent) { grid-column: span 3; }

.module-card span {
  color: var(--teal);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.module-card.primary span,
.module-card.accent span { color: rgba(21, 36, 59, 0.62); }

.operating-model {
  background: #eef3f3;
}

.model-steps {
  display: grid;
  gap: 0;
  margin: 0 auto;
  max-width: 1120px;
}

.model-steps article {
  border-top: 1px solid rgba(21, 36, 59, 0.14);
  display: grid;
  gap: 24px;
  grid-template-columns: 170px minmax(0, 1fr);
  padding: 28px 0;
}

.model-steps span {
  color: var(--ocean);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.model-steps h3 {
  margin: 0;
}

.intelligence-layer {
  align-items: center;
  display: grid;
  gap: clamp(32px, 5vw, 72px);
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr);
}

.intelligence-copy h2 {
  color: var(--midnight);
  font-size: clamp(36px, 5vw, 68px);
  line-height: 1.03;
  margin: 0;
}

.intelligence-copy p:not(.eyebrow) {
  color: rgba(21, 36, 59, 0.66);
  font-size: 17px;
  font-weight: 650;
  line-height: 1.7;
}

.signal-matrix {
  background: var(--midnight);
  color: var(--white);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  padding: 12px 28px;
}

.signal-matrix span,
.signal-matrix strong {
  border-bottom: 1px solid rgba(248, 250, 252, 0.12);
  padding: 18px 0;
}

.signal-matrix span {
  color: rgba(248, 250, 252, 0.68);
  font-weight: 750;
}

.signal-matrix strong {
  color: var(--teal);
  font-weight: 950;
  text-align: right;
}

.governance-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.governance-grid span {
  background: rgba(31, 78, 121, 0.08);
  border-left: 4px solid var(--teal);
  color: rgba(21, 36, 59, 0.78);
  font-weight: 850;
  padding: 18px;
}

.platform-cta {
  background: var(--midnight);
  color: var(--white);
  padding: clamp(72px, 8vw, 110px) clamp(22px, 5vw, 72px);
  text-align: center;
}

.platform-cta h2 {
  color: var(--white);
  margin: 0 auto 30px;
}

.platform-cta .eyebrow {
  color: var(--teal);
}

@media (max-width: 980px) {
  .platform-hero,
  .split-heading,
  .intelligence-layer {
    grid-template-columns: 1fr;
  }

  .platform-command {
    min-height: auto;
  }

  .platform-overview-grid,
  .governance-grid {
    grid-template-columns: 1fr;
  }

  .module-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .module-card,
  .module-card.primary,
  .module-card.accent,
  .module-card:not(.primary):not(.accent) {
    grid-column: auto;
    grid-row: auto;
  }
}

@media (max-width: 660px) {
  .platform-hero {
    padding-top: 112px;
  }

  .command-grid,
  .module-board {
    grid-template-columns: 1fr;
  }

  .command-panel,
  .command-panel.wide,
  .command-panel.tall,
  .command-panel.muted {
    grid-column: auto;
    grid-row: auto;
  }

  .model-steps article {
    grid-template-columns: 1fr;
  }
}

/* Solutions page */
.solutions-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(380px, 1.1fr);
  gap: clamp(36px, 5vw, 80px);
  align-items: center;
  min-height: 92vh;
  padding: clamp(132px, 14vw, 180px) clamp(22px, 6vw, 82px) clamp(72px, 9vw, 118px);
  overflow: hidden;
  background:
    linear-gradient(115deg, rgba(247, 251, 255, 0.95) 0%, rgba(231, 242, 250, 0.84) 45%, rgba(9, 24, 42, 0.2) 100%),
    url('./hero-maritime-intelligence.png') center / cover no-repeat;
}

.solutions-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 22% 36%, rgba(89, 204, 214, 0.22), transparent 28%),
    repeating-radial-gradient(circle at 70% 46%, rgba(31, 78, 121, 0.18) 0 1px, transparent 1px 84px);
  pointer-events: none;
}

.solutions-hero-copy,
.solutions-command {
  position: relative;
  z-index: 1;
}

.solutions-hero h1 {
  margin: 0 0 24px;
  max-width: 820px;
  color: var(--navy);
  font-size: clamp(58px, 8vw, 126px);
  line-height: 0.86;
  letter-spacing: 0;
}

.solutions-hero-copy > p:not(.eyebrow) {
  max-width: 780px;
  color: rgba(21, 36, 59, 0.76);
  font-size: clamp(22px, 2.4vw, 35px);
  font-weight: 850;
  line-height: 1.28;
}

.solutions-command {
  min-height: 620px;
  border: 1px solid rgba(197, 220, 244, 0.56);
  border-radius: 44px;
  background:
    linear-gradient(145deg, rgba(8, 22, 39, 0.88), rgba(17, 55, 85, 0.84)),
    radial-gradient(circle at 50% 50%, rgba(89, 204, 214, 0.26), transparent 34%);
  box-shadow: 0 42px 100px rgba(9, 24, 42, 0.36);
  overflow: hidden;
}

.command-radar {
  position: absolute;
  inset: 42px 42px 188px;
  display: grid;
  place-items: center;
  border-radius: 36px;
  background:
    linear-gradient(135deg, rgba(88, 147, 199, 0.18), transparent 52%),
    repeating-radial-gradient(circle, rgba(197, 220, 244, 0.26) 0 1px, transparent 1px 70px);
  border: 1px solid rgba(197, 220, 244, 0.22);
}

.command-radar span {
  position: absolute;
  width: 54%;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(89, 204, 214, 0.3);
  box-shadow: inset 0 0 46px rgba(89, 204, 214, 0.12);
}

.command-radar span:nth-child(2) { width: 74%; opacity: 0.72; }
.command-radar span:nth-child(3) { width: 28%; background: rgba(197, 220, 244, 0.08); }

.command-radar strong {
  width: 190px;
  height: 190px;
  display: grid;
  place-items: center;
  padding: 28px;
  border-radius: 50%;
  color: var(--navy);
  text-align: center;
  font-size: 28px;
  line-height: 1.02;
  background: linear-gradient(145deg, #f7fbff, #b9d4f4);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.26), inset -18px -24px 42px rgba(31, 78, 121, 0.2), inset 14px 18px 28px rgba(255, 255, 255, 0.86);
}

.command-readouts {
  position: absolute;
  left: 32px;
  right: 32px;
  bottom: 32px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.command-readouts article {
  padding: 20px;
  border: 1px solid rgba(197, 220, 244, 0.18);
  border-radius: 22px;
  background: rgba(247, 251, 255, 0.08);
}

.command-readouts span,
.command-readouts strong {
  display: block;
}

.command-readouts span {
  color: rgba(197, 220, 244, 0.68);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.command-readouts strong {
  margin-top: 6px;
  color: var(--white);
  font-size: 26px;
}

.solution-anchor-bar {
  position: sticky;
  top: 92px;
  z-index: 20;
  display: flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
  padding: 16px clamp(18px, 4vw, 54px);
  background: rgba(247, 251, 255, 0.88);
  border-block: 1px solid rgba(21, 36, 59, 0.08);
  backdrop-filter: blur(18px);
}

.solution-anchor-bar a {
  color: var(--navy);
  padding: 11px 18px;
  border-radius: 999px;
  background: rgba(31, 78, 121, 0.08);
  font-weight: 900;
  text-decoration: none;
}

.solution-intro {
  background: var(--white);
  text-align: center;
}

.solution-intro h2 {
  max-width: 1120px;
  margin: 0 auto;
  color: var(--navy);
  font-size: clamp(38px, 5.4vw, 80px);
  line-height: 0.96;
}

.solution-lanes {
  background: var(--midnight);
  color: var(--white);
}

.solution-lanes h2,
.solution-lanes h3,
.solution-lanes .section-heading p {
  color: var(--white);
}

.lane-stack {
  display: grid;
  gap: 18px;
}

.lane-stack article {
  display: grid;
  grid-template-columns: 92px minmax(260px, 0.85fr) minmax(320px, 1.15fr);
  gap: clamp(18px, 3vw, 42px);
  align-items: start;
  padding: clamp(26px, 4vw, 46px);
  border: 1px solid rgba(197, 220, 244, 0.14);
  border-radius: 30px;
  background: linear-gradient(135deg, rgba(20, 56, 88, 0.78), rgba(8, 18, 31, 0.78));
}

.lane-number {
  color: var(--teal);
  font-size: 34px;
  font-weight: 950;
}

.lane-stack h3 {
  margin: 0 0 14px;
  font-size: clamp(28px, 3vw, 48px);
  line-height: 1;
}

.lane-stack p,
.lane-stack li {
  color: rgba(247, 251, 255, 0.72);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.5;
}

.lane-stack ul {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
  padding: 0;
  list-style: none;
}

.lane-stack li {
  position: relative;
  padding-left: 22px;
}

.lane-stack li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--teal);
}

.consulting-system {
  background: linear-gradient(180deg, #f7fbff, #eaf3fb);
}

.consulting-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.consulting-board article {
  min-height: 360px;
  padding: clamp(28px, 4vw, 44px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(226, 239, 250, 0.86));
  border-radius: 10px;
  box-shadow: 0 24px 70px rgba(31, 78, 121, 0.12);
}

.consulting-board h3 {
  margin: 0 0 22px;
  color: var(--navy);
  font-size: clamp(26px, 3vw, 44px);
  line-height: 1.02;
}

.assurance-model {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  background: #07111f;
  color: var(--white);
}

.assurance-model h2 {
  color: var(--white);
  margin: 0 0 22px;
  font-size: clamp(42px, 6vw, 92px);
  line-height: 0.92;
}

.assurance-model p:not(.eyebrow) {
  color: rgba(247, 251, 255, 0.72);
  font-size: 22px;
  font-weight: 800;
  line-height: 1.5;
}

.assurance-equation {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.assurance-equation span,
.assurance-equation strong {
  display: grid;
  place-items: center;
  min-height: 116px;
  padding: 18px;
  text-align: center;
  border-radius: 28px;
  border: 1px solid rgba(197, 220, 244, 0.18);
  font-weight: 950;
}

.assurance-equation span {
  color: var(--ice);
  background: rgba(197, 220, 244, 0.08);
}

.assurance-equation strong {
  grid-column: 1 / -1;
  min-height: 150px;
  color: var(--navy);
  font-size: clamp(30px, 4vw, 58px);
  background: linear-gradient(135deg, #59ccd6, #c5dcf4);
}

.transformation-flow {
  background: var(--white);
}

.rollout-timeline {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid rgba(31, 78, 121, 0.16);
  border-radius: 34px;
  overflow: hidden;
}

.rollout-timeline article {
  min-height: 340px;
  padding: clamp(26px, 3vw, 38px);
  background: #f7fbff;
  border-right: 1px solid rgba(31, 78, 121, 0.12);
}

.rollout-timeline article:nth-child(even) {
  background: #edf5fb;
}

.rollout-timeline article:last-child {
  border-right: 0;
}

.rollout-timeline span {
  color: var(--teal-dark);
  font-size: 18px;
  font-weight: 950;
}

.rollout-timeline h3 {
  margin: 36px 0 18px;
  color: var(--navy);
  font-size: 29px;
  line-height: 1.02;
}

.adoption-band {
  padding: clamp(70px, 8vw, 110px) clamp(22px, 6vw, 82px);
  background:
    linear-gradient(90deg, rgba(8, 22, 39, 0.94), rgba(16, 54, 84, 0.86)),
    url('./hero-bridge-operations.png') center / cover no-repeat;
  color: var(--white);
}

.adoption-band > div {
  max-width: 1120px;
}

.adoption-band h2 {
  color: var(--white);
  margin: 0 0 22px;
  font-size: clamp(42px, 6vw, 86px);
  line-height: 0.94;
}

.adoption-band p:not(.eyebrow) {
  color: rgba(247, 251, 255, 0.76);
  font-size: clamp(22px, 2.3vw, 32px);
  font-weight: 850;
  line-height: 1.45;
}

.serve-outcomes {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
  gap: 22px;
  background: linear-gradient(180deg, #f7fbff, #eaf3fb);
}

.serve-panel,
.outcome-panel {
  padding: clamp(30px, 5vw, 54px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.76);
}

.serve-list {
  display: grid;
  gap: 14px;
}

.serve-list article {
  padding: 18px 0;
  border-bottom: 1px solid rgba(31, 78, 121, 0.14);
}

.serve-list article:last-child { border-bottom: 0; }

.serve-list h3,
.outcome-panel h2 {
  color: var(--navy);
}

.serve-list h3 {
  margin: 0 0 8px;
  font-size: 25px;
}

.outcome-panel h2 {
  margin: 0 0 28px;
  font-size: clamp(38px, 5vw, 72px);
  line-height: 0.94;
}

.outcome-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.outcome-grid span {
  min-height: 104px;
  display: flex;
  align-items: flex-end;
  padding: 18px;
  border-radius: 22px;
  color: var(--navy);
  background: linear-gradient(145deg, rgba(197, 220, 244, 0.72), rgba(247, 251, 255, 0.94));
  font-weight: 950;
}

.solutions-cta {
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  text-align: center;
  background: var(--midnight);
  color: var(--white);
}

.solutions-cta h2 {
  max-width: 1100px;
  margin: 0 auto 24px;
  color: var(--white);
  font-size: clamp(44px, 6.3vw, 94px);
  line-height: 0.92;
}

.solutions-cta p:not(.eyebrow) {
  max-width: 980px;
  margin: 0 auto 30px;
  color: rgba(247, 251, 255, 0.74);
  font-size: 24px;
  font-weight: 850;
  line-height: 1.45;
}

.centered-actions {
  justify-content: center;
}

@media (max-width: 1050px) {
  .solutions-hero,
  .assurance-model,
  .serve-outcomes {
    grid-template-columns: 1fr;
  }

  .solutions-command {
    min-height: 560px;
  }

  .lane-stack article {
    grid-template-columns: 1fr;
  }

  .consulting-board,
  .rollout-timeline {
    grid-template-columns: 1fr;
  }

  .rollout-timeline article {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(31, 78, 121, 0.12);
  }

  .rollout-timeline article:last-child {
    border-bottom: 0;
  }
}

@media (max-width: 680px) {
  .solutions-hero {
    padding-top: 118px;
  }

  .solutions-command {
    min-height: 520px;
    border-radius: 30px;
  }

  .command-radar {
    inset: 24px 24px 204px;
  }

  .command-readouts,
  .lane-stack ul,
  .assurance-equation,
  .outcome-grid {
    grid-template-columns: 1fr;
  }

  .solution-anchor-bar {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
  }
}

/* Features page */
.features-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  gap: clamp(34px, 5vw, 78px);
  align-items: center;
  min-height: 94vh;
  padding: clamp(136px, 14vw, 186px) clamp(22px, 6vw, 82px) clamp(78px, 9vw, 124px);
  overflow: hidden;
  background:
    linear-gradient(115deg, rgba(247, 251, 255, 0.96) 0%, rgba(232, 244, 252, 0.9) 44%, rgba(8, 22, 39, 0.2) 100%),
    url('./hero-fleet-analytics-room.png') center / cover no-repeat;
}

.features-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(247, 251, 255, 0.88), rgba(247, 251, 255, 0.12)),
    repeating-linear-gradient(90deg, rgba(31, 78, 121, 0.08) 0 1px, transparent 1px 92px),
    repeating-linear-gradient(0deg, rgba(31, 78, 121, 0.06) 0 1px, transparent 1px 92px);
  pointer-events: none;
}

.features-hero-copy,
.feature-command-map {
  position: relative;
  z-index: 1;
}

.features-hero h1 {
  margin: 0 0 24px;
  max-width: 900px;
  color: var(--navy);
  font-size: clamp(52px, 7vw, 108px);
  line-height: 0.88;
  letter-spacing: 0;
}

.features-hero-copy > p:not(.eyebrow) {
  max-width: 820px;
  color: rgba(21, 36, 59, 0.76);
  font-size: clamp(21px, 2.2vw, 32px);
  font-weight: 850;
  line-height: 1.32;
}

.feature-command-map {
  min-height: 660px;
  border-radius: 44px;
  border: 1px solid rgba(197, 220, 244, 0.5);
  background:
    radial-gradient(circle at 50% 50%, rgba(89, 204, 214, 0.22), transparent 30%),
    repeating-radial-gradient(circle at 50% 50%, rgba(197, 220, 244, 0.22) 0 1px, transparent 1px 68px),
    linear-gradient(145deg, rgba(8, 22, 39, 0.94), rgba(20, 58, 90, 0.9));
  box-shadow: 0 42px 100px rgba(9, 24, 42, 0.36);
  overflow: hidden;
}

.feature-core {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 260px;
  height: 260px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 12px;
  padding: 30px;
  border-radius: 50%;
  text-align: center;
  transform: translate(-50%, -50%);
  background: linear-gradient(145deg, #f7fbff, #b9d4f4);
  box-shadow: 0 32px 70px rgba(0, 0, 0, 0.3), inset -24px -26px 44px rgba(31, 78, 121, 0.22), inset 18px 20px 30px rgba(255, 255, 255, 0.9);
}

.feature-core strong {
  color: var(--navy);
  font-size: 38px;
  line-height: 0.94;
}

.feature-core span {
  color: rgba(21, 36, 59, 0.62);
  font-size: 15px;
  font-weight: 900;
  line-height: 1.25;
}

.feature-node {
  position: absolute;
  min-width: 126px;
  padding: 14px 18px;
  border: 1px solid rgba(197, 220, 244, 0.26);
  border-radius: 999px;
  color: var(--ice);
  background: rgba(247, 251, 255, 0.1);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.2);
  font-size: 15px;
  font-weight: 950;
  text-align: center;
}

.node-a { left: 10%; top: 18%; }
.node-b { left: 44%; top: 9%; }
.node-c { right: 9%; top: 20%; }
.node-d { right: 12%; top: 47%; }
.node-e { right: 18%; bottom: 15%; }
.node-f { left: 40%; bottom: 9%; }
.node-g { left: 9%; bottom: 21%; }
.node-h { left: 8%; top: 48%; }

.feature-anchor-bar {
  position: sticky;
  top: 92px;
  z-index: 20;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 16px clamp(18px, 4vw, 54px);
  border-block: 1px solid rgba(21, 36, 59, 0.08);
  background: rgba(247, 251, 255, 0.9);
  backdrop-filter: blur(18px);
}

.feature-anchor-bar a {
  color: var(--navy);
  padding: 11px 18px;
  border-radius: 999px;
  background: rgba(31, 78, 121, 0.08);
  font-weight: 900;
  text-decoration: none;
}

.feature-system-intro {
  background: var(--white);
  text-align: center;
}

.feature-system-intro h2 {
  max-width: 1160px;
  margin: 0 auto 34px;
  color: var(--navy);
  font-size: clamp(38px, 5.4vw, 82px);
  line-height: 0.96;
}

.feature-question-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.feature-question-strip span {
  display: grid;
  place-items: center;
  min-height: 118px;
  padding: 18px;
  border-radius: 22px;
  background: #edf5fb;
  color: var(--navy);
  font-weight: 950;
  line-height: 1.2;
}

.review-lifecycle {
  background: var(--midnight);
  color: var(--white);
}

.review-lifecycle h2,
.review-lifecycle .section-heading p {
  color: var(--white);
}

.lifecycle-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid rgba(197, 220, 244, 0.16);
  border-radius: 34px;
  overflow: hidden;
}

.lifecycle-rail article {
  min-height: 380px;
  padding: clamp(28px, 3.2vw, 42px);
  border-right: 1px solid rgba(197, 220, 244, 0.16);
  background: linear-gradient(180deg, rgba(31, 78, 121, 0.32), rgba(8, 18, 31, 0.76));
}

.lifecycle-rail article:last-child {
  border-right: 0;
}

.lifecycle-rail span {
  color: var(--teal);
  font-size: 18px;
  font-weight: 950;
}

.lifecycle-rail h3 {
  margin: 84px 0 18px;
  color: var(--white);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1;
}

.lifecycle-rail p {
  color: rgba(247, 251, 255, 0.72);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.5;
}

.competency-development {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(32px, 5vw, 82px);
  align-items: center;
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  background: linear-gradient(180deg, #f7fbff, #eaf3fb);
}

.competency-copy h2 {
  margin: 0 0 24px;
  color: var(--navy);
  font-size: clamp(42px, 5.6vw, 82px);
  line-height: 0.94;
}

.competency-copy p:not(.eyebrow) {
  color: rgba(21, 36, 59, 0.72);
  font-size: 22px;
  font-weight: 800;
  line-height: 1.48;
}

.competency-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.competency-grid article {
  min-height: 270px;
  padding: clamp(24px, 3vw, 34px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 24px 70px rgba(31, 78, 121, 0.12);
}

.competency-grid span {
  display: inline-grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 18px;
  color: var(--navy);
  background: var(--teal);
  font-weight: 950;
}

.competency-grid h3 {
  margin: 26px 0 14px;
  color: var(--navy);
  font-size: 28px;
  line-height: 1;
}

.analytics-intelligence {
  background: var(--white);
}

.analytics-cockpit {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: minmax(220px, auto);
  gap: 16px;
}

.analytics-panel {
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 30px;
  background: linear-gradient(145deg, #edf5fb, #ffffff);
  overflow: hidden;
}

.analytics-panel p {
  margin: 0 0 18px;
  color: var(--teal-dark);
  font-size: 15px;
  font-weight: 950;
  text-transform: uppercase;
}

.analytics-panel strong {
  color: var(--navy);
  font-size: clamp(22px, 2.4vw, 34px);
  line-height: 1.08;
}

.matrix-panel {
  grid-column: span 2;
  grid-row: span 2;
  background: linear-gradient(145deg, #07111f, #173d60);
}

.matrix-panel p,
.matrix-panel strong {
  color: var(--white);
}

.mini-matrix {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 30px 0;
}

.mini-matrix span {
  aspect-ratio: 1;
  border-radius: 16px;
  background: rgba(197, 220, 244, 0.12);
  border: 1px solid rgba(197, 220, 244, 0.2);
}

.mini-matrix span:nth-child(5),
.mini-matrix span:nth-child(9) {
  background: linear-gradient(135deg, rgba(89, 204, 214, 0.78), rgba(197, 220, 244, 0.34));
}

.assurance-panel {
  grid-column: span 2;
  background: linear-gradient(135deg, #59ccd6, #c5dcf4);
}

.maritime-operations {
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  background: #07111f;
  color: var(--white);
}

.maritime-operations h2,
.maritime-operations .section-heading p {
  color: var(--white);
}

.operations-map {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, 0.9fr);
  gap: 20px;
}

.role-workspaces {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.role-workspaces article,
.vessel-ledger {
  padding: clamp(22px, 3vw, 34px);
  border: 1px solid rgba(197, 220, 244, 0.16);
  border-radius: 28px;
  background: rgba(247, 251, 255, 0.08);
}

.role-workspaces span {
  color: var(--teal);
  font-weight: 950;
}

.role-workspaces h3,
.vessel-ledger h3 {
  margin: 18px 0 12px;
  color: var(--white);
  font-size: 28px;
  line-height: 1;
}

.role-workspaces p,
.vessel-ledger li {
  color: rgba(247, 251, 255, 0.72);
  font-weight: 800;
  line-height: 1.45;
}

.vessel-ledger {
  background:
    linear-gradient(180deg, rgba(31, 78, 121, 0.36), rgba(247, 251, 255, 0.08)),
    url('./hero-bridge-operations.png') center / cover no-repeat;
}

.vessel-ledger ul {
  display: grid;
  gap: 16px;
  margin: 30px 0 0;
  padding: 0;
  list-style: none;
}

.vessel-ledger li {
  padding-left: 18px;
  border-left: 4px solid var(--teal);
}

.governance-config {
  background: linear-gradient(180deg, #f7fbff, #eaf3fb);
}

.governance-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.governance-feature-grid article {
  min-height: 260px;
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 24px 70px rgba(31, 78, 121, 0.1);
}

.governance-feature-grid h3 {
  margin: 0 0 18px;
  color: var(--navy);
  font-size: 30px;
  line-height: 1;
}

.features-cta {
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  text-align: center;
  background: var(--midnight);
  color: var(--white);
}

.features-cta h2 {
  max-width: 1180px;
  margin: 0 auto 24px;
  color: var(--white);
  font-size: clamp(42px, 6vw, 88px);
  line-height: 0.94;
}

.features-cta p:not(.eyebrow) {
  max-width: 980px;
  margin: 0 auto 30px;
  color: rgba(247, 251, 255, 0.74);
  font-size: 24px;
  font-weight: 850;
  line-height: 1.45;
}

@media (max-width: 1080px) {
  .features-hero,
  .competency-development,
  .operations-map {
    grid-template-columns: 1fr;
  }

  .feature-question-strip,
  .lifecycle-rail,
  .governance-feature-grid {
    grid-template-columns: 1fr;
  }

  .lifecycle-rail article {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(197, 220, 244, 0.16);
  }

  .lifecycle-rail article:last-child {
    border-bottom: 0;
  }

  .lifecycle-rail h3 {
    margin-top: 38px;
  }

  .analytics-cockpit {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .features-hero {
    padding-top: 118px;
  }

  .feature-command-map {
    min-height: 560px;
    border-radius: 30px;
  }

  .feature-core {
    width: 210px;
    height: 210px;
  }

  .feature-node {
    min-width: 96px;
    padding: 11px 12px;
    font-size: 12px;
  }

  .competency-grid,
  .analytics-cockpit,
  .role-workspaces {
    grid-template-columns: 1fr;
  }

  .matrix-panel,
  .assurance-panel {
    grid-column: auto;
    grid-row: auto;
  }

  .feature-anchor-bar {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
  }
}

/* Hero and type scale refinement for secondary pages */
.solutions-hero,
.features-hero {
  grid-template-columns: minmax(360px, 0.96fr) minmax(420px, 1.04fr);
  gap: clamp(24px, 4vw, 46px);
  min-height: 82vh;
  padding: 116px clamp(18px, 4vw, 54px) 34px;
}

.solutions-hero::before,
.features-hero::before {
  opacity: 0.72;
}

.solutions-hero-copy,
.features-hero-copy {
  align-self: center;
  max-width: 760px;
}

.solutions-hero h1,
.features-hero h1 {
  max-width: 920px;
  font-size: clamp(38px, 3.45vw, 48px);
  line-height: 1.03;
}

.solutions-hero-copy > p:not(.eyebrow),
.features-hero-copy > p:not(.eyebrow) {
  max-width: 690px;
  margin: 24px 0 0;
  color: rgba(47, 52, 72, 0.78);
  font-size: clamp(16px, 1.55vw, 20px);
  font-weight: 600;
  line-height: 1.45;
}

.solutions-command,
.feature-command-map {
  min-height: 0;
  height: clamp(430px, 42vw, 530px);
  border-radius: var(--radius-lg);
}

.command-radar {
  inset: 28px 28px 158px;
}

.command-radar strong {
  width: 150px;
  height: 150px;
  font-size: 22px;
}

.command-readouts {
  left: 24px;
  right: 24px;
  bottom: 24px;
}

.command-readouts article {
  padding: 16px;
  border-radius: 18px;
}

.command-readouts strong {
  font-size: 20px;
}

.feature-core {
  width: 210px;
  height: 210px;
}

.feature-core strong {
  font-size: 30px;
}

.feature-core span {
  font-size: 13px;
}

.feature-node {
  min-width: 112px;
  padding: 12px 14px;
  font-size: 13px;
}

.solution-intro h2,
.feature-system-intro h2 {
  max-width: 980px;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.02;
}

.lane-stack h3,
.consulting-board h3,
.competency-grid h3,
.role-workspaces h3,
.vessel-ledger h3,
.governance-feature-grid h3 {
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.08;
}

.lane-stack p,
.lane-stack li,
.assurance-model p:not(.eyebrow),
.adoption-band p:not(.eyebrow),
.solutions-cta p:not(.eyebrow),
.competency-copy p:not(.eyebrow),
.lifecycle-rail p,
.features-cta p:not(.eyebrow) {
  font-size: clamp(16px, 1.35vw, 19px);
  line-height: 1.5;
}

.assurance-model h2,
.adoption-band h2,
.outcome-panel h2,
.solutions-cta h2,
.competency-copy h2,
.features-cta h2 {
  font-size: clamp(34px, 4.6vw, 62px);
  line-height: 1.02;
}

.analytics-panel strong {
  font-size: clamp(20px, 2vw, 28px);
}

.feature-question-strip span {
  min-height: 96px;
}

.lifecycle-rail h3 {
  margin-top: 54px;
}

@media (max-width: 980px) {
  .solutions-hero,
  .features-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 112px;
  }

  .solutions-command,
  .feature-command-map {
    height: clamp(360px, 72vw, 480px);
  }
}

@media (max-width: 680px) {
  .solutions-hero,
  .features-hero {
    padding-top: 112px;
  }

  .command-radar {
    inset: 22px 22px 172px;
  }

  .feature-core {
    width: 176px;
    height: 176px;
  }

  .feature-core strong {
    font-size: 24px;
  }

  .solutions-hero h1,
  .features-hero h1 {
    font-size: 32px;
  }
}

/* About Stripes page */
.about-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(360px, 0.96fr) minmax(420px, 1.04fr);
  gap: clamp(24px, 4vw, 46px);
  align-items: center;
  min-height: 82vh;
  padding: 116px clamp(18px, 4vw, 54px) 34px;
  overflow: hidden;
  background:
    linear-gradient(115deg, rgba(247, 251, 255, 0.96) 0%, rgba(232, 244, 252, 0.88) 44%, rgba(8, 22, 39, 0.16) 100%),
    url('./hero-bridge-operations.png') center / cover no-repeat;
}

.about-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 34%, rgba(89, 204, 214, 0.22), transparent 28%),
    repeating-radial-gradient(ellipse at 70% 48%, rgba(31, 78, 121, 0.18) 0 1px, transparent 1px 42px);
  pointer-events: none;
}

.about-hero-copy,
.about-hero-panel {
  position: relative;
  z-index: 1;
}

.about-hero-copy {
  max-width: 760px;
}

.about-hero h1 {
  max-width: 920px;
  color: var(--navy);
  font-size: clamp(38px, 3.45vw, 48px);
  line-height: 1.03;
}

.about-hero-copy > p:not(.eyebrow) {
  max-width: 690px;
  margin: 24px 0 0;
  color: rgba(47, 52, 72, 0.78);
  font-size: clamp(16px, 1.55vw, 20px);
  font-weight: 600;
  line-height: 1.45;
}

.about-hero-panel {
  height: clamp(430px, 42vw, 530px);
  border: 1px solid rgba(197, 220, 244, 0.46);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 50% 42%, rgba(89, 204, 214, 0.24), transparent 30%),
    repeating-radial-gradient(circle at 50% 42%, rgba(197, 220, 244, 0.24) 0 1px, transparent 1px 62px),
    linear-gradient(145deg, rgba(8, 22, 39, 0.92), rgba(18, 55, 86, 0.9));
  box-shadow: var(--hard-shadow);
  overflow: hidden;
}

.about-compass {
  position: absolute;
  left: 50%;
  top: 43%;
  width: 210px;
  height: 210px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  padding: 28px;
  border-radius: 50%;
  text-align: center;
  transform: translate(-50%, -50%);
  background: linear-gradient(145deg, #f7fbff, #bdd6f0);
  box-shadow: 0 32px 70px rgba(0, 0, 0, 0.3), inset -20px -24px 42px rgba(31, 78, 121, 0.22), inset 18px 20px 30px rgba(255, 255, 255, 0.9);
}

.about-compass span {
  position: absolute;
  inset: -32px;
  border: 1px solid rgba(197, 220, 244, 0.5);
  border-radius: 50%;
}

.about-compass strong {
  color: var(--navy);
  font-size: 34px;
  line-height: 1;
}

.about-compass em {
  color: rgba(21, 36, 59, 0.66);
  font-size: 13px;
  font-style: normal;
  font-weight: 900;
  text-transform: uppercase;
}

.about-panel-grid {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.about-panel-grid article {
  min-height: 90px;
  padding: 16px;
  border: 1px solid rgba(197, 220, 244, 0.18);
  border-radius: 18px;
  background: rgba(247, 251, 255, 0.09);
}

.about-panel-grid span,
.about-panel-grid strong {
  display: block;
}

.about-panel-grid span {
  color: rgba(197, 220, 244, 0.68);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.about-panel-grid strong {
  margin-top: 7px;
  color: var(--white);
  font-size: 20px;
  line-height: 1.1;
}

.about-diptych {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  padding: 14px;
  background: rgba(247, 251, 255, 0.54);
  backdrop-filter: blur(18px);
}

.diptych-pane {
  position: relative;
  min-height: 100%;
  overflow: hidden;
  border-radius: calc(var(--radius-lg) - 14px);
  background: var(--midnight);
  isolation: isolate;
}

.diptych-pane img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.94) contrast(1.04);
  transform: scale(1.01);
}

.diptych-pane::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(180deg, rgba(8, 22, 39, 0.02) 20%, rgba(8, 22, 39, 0.9) 100%),
    linear-gradient(90deg, rgba(8, 22, 39, 0.45), transparent 54%);
}

.platform-pane::after {
  background:
    linear-gradient(180deg, rgba(8, 22, 39, 0.08) 16%, rgba(8, 22, 39, 0.9) 100%),
    linear-gradient(90deg, rgba(31, 78, 121, 0.48), rgba(8, 22, 39, 0.2));
}

.diptych-pane > div {
  position: absolute;
  left: clamp(18px, 3vw, 30px);
  right: clamp(18px, 3vw, 30px);
  bottom: clamp(18px, 3vw, 30px);
  z-index: 2;
}

.diptych-pane span {
  position: absolute;
  top: clamp(18px, 3vw, 28px);
  display: inline-flex;
  padding: 9px 13px;
  border: 1px solid rgba(197, 220, 244, 0.72);
  border-radius: 999px;
  color: var(--navy);
  background: rgba(247, 251, 255, 0.94);
  box-shadow: 0 14px 36px rgba(8, 22, 39, 0.34);
  backdrop-filter: blur(14px);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.academy-pane span {
  left: clamp(18px, 3vw, 28px);
  border-color: rgba(31, 78, 121, 0.22);
}

.platform-pane span {
  right: clamp(18px, 3vw, 28px);
  border-color: rgba(31, 78, 121, 0.22);
}

.diptych-pane strong {
  display: block;
  max-width: 360px;
  color: var(--white);
  font-size: clamp(25px, 2.6vw, 38px);
  line-height: 1.02;
}

.diptych-pane p {
  max-width: 360px;
  margin: 12px 0 0;
  color: rgba(247, 251, 255, 0.74);
  font-size: 15px;
  font-weight: 750;
  line-height: 1.42;
}

.diptych-bridge {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 4;
  display: grid;
  place-items: center;
  gap: 2px;
  width: 132px;
  height: 132px;
  border: 1px solid rgba(197, 220, 244, 0.5);
  border-radius: 50%;
  color: var(--navy);
  text-align: center;
  transform: translate(-50%, -50%);
  background: linear-gradient(145deg, rgba(247, 251, 255, 0.96), rgba(197, 220, 244, 0.9));
  box-shadow: 0 22px 60px rgba(8, 22, 39, 0.32);
}

.diptych-bridge span {
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.diptych-bridge strong {
  color: var(--teal-dark);
  font-size: 22px;
  line-height: 1;
}

.about-anchor-bar {
  position: sticky;
  top: 92px;
  z-index: 20;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 16px clamp(18px, 4vw, 54px);
  border-block: 1px solid rgba(21, 36, 59, 0.08);
  background: rgba(247, 251, 255, 0.9);
  backdrop-filter: blur(18px);
}

.about-anchor-bar a {
  color: var(--navy);
  padding: 11px 18px;
  border-radius: 999px;
  background: rgba(31, 78, 121, 0.08);
  font-weight: 900;
  text-decoration: none;
}

.about-statement {
  background: var(--white);
  text-align: center;
}

.about-statement h2 {
  max-width: 1120px;
  margin: 0 auto 36px;
  color: var(--navy);
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.02;
}

.about-model-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  text-align: left;
}

.about-model-grid article {
  min-height: 330px;
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 10px;
  background: linear-gradient(180deg, rgba(247, 251, 255, 0.94), rgba(226, 239, 250, 0.88));
}

.about-model-grid span {
  color: var(--teal-dark);
  font-weight: 950;
}

.about-model-grid h3 {
  margin: 34px 0 16px;
  color: var(--navy);
  font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.04;
}

.about-model-grid p {
  color: rgba(21, 36, 59, 0.7);
  font-size: 17px;
  font-weight: 750;
  line-height: 1.52;
}

.academy-section {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(30px, 5vw, 78px);
  align-items: center;
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  background: #07111f;
  color: var(--white);
}

.academy-copy h2 {
  color: var(--white);
  margin: 0 0 24px;
  font-size: clamp(34px, 4.6vw, 62px);
  line-height: 1.02;
}

.academy-copy p:not(.eyebrow) {
  color: rgba(247, 251, 255, 0.72);
  font-size: clamp(16px, 1.45vw, 20px);
  font-weight: 750;
  line-height: 1.58;
}

.academy-ledger {
  display: grid;
  gap: 14px;
}

.academy-ledger article {
  padding: clamp(22px, 3vw, 34px);
  border: 1px solid rgba(197, 220, 244, 0.18);
  border-radius: 28px;
  background: rgba(247, 251, 255, 0.08);
}

.academy-ledger span {
  color: var(--teal);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}

.academy-ledger strong {
  display: block;
  margin-top: 10px;
  color: var(--white);
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.12;
}

.intelligence-section {
  background: linear-gradient(180deg, #f7fbff, #eaf3fb);
}

.intelligence-board {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.intelligence-board article {
  min-height: 310px;
  padding: clamp(24px, 3vw, 34px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 24px 70px rgba(31, 78, 121, 0.1);
}

.intelligence-board h3 {
  margin: 0 0 18px;
  color: var(--navy);
  font-size: clamp(24px, 2.3vw, 32px);
  line-height: 1.04;
}

.intelligence-board p {
  color: rgba(21, 36, 59, 0.68);
  font-size: 16px;
  font-weight: 750;
  line-height: 1.5;
}

.why-stripes {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.72fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  background: var(--white);
}

.why-copy h2 {
  color: var(--navy);
  margin: 0 0 24px;
  font-size: clamp(34px, 4.6vw, 62px);
  line-height: 1.02;
}

.why-copy p:not(.eyebrow) {
  color: rgba(21, 36, 59, 0.72);
  font-size: clamp(17px, 1.55vw, 21px);
  font-weight: 750;
  line-height: 1.58;
}

.why-stack {
  display: grid;
  gap: 10px;
}

.why-stack span {
  padding: 20px 22px;
  border-left: 5px solid var(--teal);
  color: var(--navy);
  background: #edf5fb;
  font-size: 18px;
  font-weight: 950;
}

.about-cta {
  padding: clamp(76px, 9vw, 126px) clamp(22px, 6vw, 82px);
  text-align: center;
  background: var(--midnight);
  color: var(--white);
}

.about-cta h2 {
  max-width: 1120px;
  margin: 0 auto 30px;
  color: var(--white);
  font-size: clamp(34px, 4.6vw, 62px);
  line-height: 1.02;
}

.about-page-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  margin-top: 28px;
  padding: 14px 20px;
  border-radius: 999px;
  color: var(--white);
  background: var(--midnight);
  font-weight: 950;
  text-decoration: none;
}

.about-page-link::after {
  content: "↗";
  margin-left: 10px;
  font-size: 14px;
}

@media (max-width: 1040px) {
  .about-hero,
  .academy-section,
  .why-stripes {
    grid-template-columns: 1fr;
  }

  .about-model-grid,
  .intelligence-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .about-hero {
    min-height: auto;
    padding-top: 112px;
  }

  .about-hero h1 {
    font-size: 32px;
  }

  .about-hero-panel {
    height: clamp(360px, 82vw, 470px);
  }

  .about-panel-grid,
  .about-diptych,
  .about-model-grid,
  .intelligence-board {
    grid-template-columns: 1fr;
  }

  .about-diptych {
    height: auto;
  }

  .diptych-pane {
    min-height: 310px;
  }

  .diptych-bridge {
    top: 50%;
    width: 104px;
    height: 104px;
  }

  .about-compass {
    width: 172px;
    height: 172px;
  }

  .about-compass strong {
    font-size: 26px;
  }

  .about-anchor-bar {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
  }
}

/* Platform page alignment pass */
.platform-page .platform-hero {
  grid-template-columns: minmax(360px, 0.96fr) minmax(420px, 1.04fr);
  gap: clamp(24px, 4vw, 46px);
  min-height: 82vh;
  padding: 116px clamp(18px, 4vw, 54px) 34px;
  background:
    radial-gradient(circle at 18% 34%, rgba(86, 199, 201, 0.18), transparent 26rem),
    linear-gradient(115deg, rgba(247, 248, 244, 0.96) 0%, rgba(234, 243, 251, 0.88) 54%, rgba(31, 78, 121, 0.14) 100%);
}

.platform-page .platform-hero::before {
  background:
    radial-gradient(circle at center, rgba(86, 199, 201, 0.2), transparent 28%),
    repeating-radial-gradient(ellipse at center, rgba(31, 78, 121, 0.18) 0 1px, transparent 1px 34px);
  width: 920px;
  height: 720px;
  left: -250px;
  top: 80px;
  opacity: 0.34;
  transform: rotate(-12deg);
  inset: auto;
}

.platform-page .platform-hero-copy {
  max-width: 760px;
}

.platform-page .platform-hero h1 {
  max-width: 920px;
  font-size: clamp(38px, 3.45vw, 48px);
  line-height: 1.03;
}

.platform-page .platform-hero-copy > p:not(.eyebrow) {
  max-width: 690px;
  margin: 24px 0 0;
  color: rgba(47, 52, 72, 0.78);
  font-size: clamp(16px, 1.55vw, 20px);
  font-weight: 600;
  line-height: 1.45;
}

.platform-page .platform-command {
  height: clamp(430px, 42vw, 530px);
  min-height: 0;
  padding: clamp(18px, 3vw, 28px);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(145deg, rgba(8, 17, 28, 0.64), rgba(17, 43, 69, 0.78)),
    url("./hero-fleet-analytics-room.png") center / cover;
  box-shadow: var(--hard-shadow);
}

.platform-page .platform-command::before {
  background: linear-gradient(180deg, rgba(8, 17, 28, 0.08), rgba(8, 17, 28, 0.62));
}

.platform-page .command-topline {
  margin-bottom: 18px;
}

.platform-page .command-grid {
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.platform-page .command-panel {
  min-height: 108px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.12);
  backdrop-filter: blur(8px);
}

.platform-page .command-panel strong {
  font-size: clamp(22px, 3vw, 34px);
  margin-top: 10px;
}

.platform-page .command-panel.muted strong {
  font-size: 18px;
}

.platform-page .mini-radar {
  max-width: 154px;
  margin-top: 14px;
}

.platform-page .platform-subnav {
  top: 92px;
  justify-content: center;
  padding: 16px clamp(18px, 4vw, 54px);
  background: rgba(247, 251, 255, 0.9);
}

.platform-page .platform-section {
  padding: clamp(68px, 7vw, 104px) clamp(22px, 5vw, 72px);
}

.platform-page .platform-section-heading h2,
.platform-page .platform-cta h2,
.platform-page .intelligence-copy h2 {
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.02;
}

.platform-page .platform-section-heading {
  margin-bottom: clamp(28px, 4vw, 46px);
}

.platform-page .platform-overview-grid {
  gap: 14px;
  overflow: visible;
}

.platform-page .platform-overview-grid article {
  border: 1px solid rgba(31, 78, 121, 0.12);
  border-top: 3px solid var(--teal);
  border-radius: 10px;
  padding: 26px;
  box-shadow: 0 18px 48px rgba(31, 78, 121, 0.08);
}

.platform-page .module-board {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.platform-page .module-card,
.platform-page .module-card.primary,
.platform-page .module-card.accent,
.platform-page .module-card:not(.primary):not(.accent) {
  grid-column: auto;
  grid-row: auto;
  min-height: 230px;
  border-radius: 10px;
  padding: 26px;
}

.platform-page .module-card h3,
.platform-page .platform-overview-grid h3,
.platform-page .model-steps h3 {
  font-size: clamp(21px, 2vw, 28px);
}

.platform-page .model-steps article {
  padding: 24px 0;
}

.platform-page .intelligence-layer {
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr);
}

.platform-page .intelligence-copy p:not(.eyebrow),
.platform-page .split-heading > p {
  font-size: clamp(16px, 1.35vw, 18px);
  line-height: 1.55;
}

.platform-page .signal-matrix {
  border-radius: 28px;
  box-shadow: 0 24px 70px rgba(8, 17, 28, 0.18);
}

.platform-page .governance-grid span {
  border-radius: 10px;
  background: rgba(31, 78, 121, 0.07);
}

@media (max-width: 980px) {
  .platform-page .platform-hero,
  .platform-page .intelligence-layer {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 112px;
  }

  .platform-page .platform-command {
    height: clamp(360px, 72vw, 480px);
  }

  .platform-page .platform-overview-grid,
  .platform-page .module-board,
  .platform-page .governance-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 660px) {
  .platform-page .platform-hero h1 {
    font-size: 32px;
  }

  .platform-page .platform-subnav {
    justify-content: flex-start;
  }
}

/* Solutions hero bright blueprint variant */
.solutions-hero {
  background:
    linear-gradient(115deg, rgba(247, 251, 255, 0.98) 0%, rgba(239, 247, 252, 0.92) 58%, rgba(197, 220, 244, 0.58) 100%),
    url('./hero-maritime-intelligence.png') center / cover no-repeat;
}

.solutions-hero::before {
  background:
    radial-gradient(circle at 22% 38%, rgba(89, 204, 214, 0.2), transparent 28%),
    repeating-radial-gradient(ellipse at 72% 48%, rgba(31, 78, 121, 0.13) 0 1px, transparent 1px 38px);
  opacity: 0.42;
}

.solutions-hero .hero-actions .button:not(.secondary) {
  background: var(--midnight);
  color: var(--white);
  box-shadow: 0 18px 46px rgba(8, 17, 28, 0.16);
}

.solution-blueprint {
  display: grid;
  grid-template-rows: repeat(4, minmax(0, 1fr));
  gap: 12px;
  padding: clamp(18px, 3vw, 28px);
  background: rgba(247, 251, 255, 0.74);
  border: 1px solid rgba(31, 78, 121, 0.12);
  backdrop-filter: blur(18px);
  box-shadow: var(--hard-shadow);
}

.solution-blueprint::before {
  content: none;
}

.blueprint-line {
  position: absolute;
  left: clamp(42px, 5vw, 62px);
  top: 48px;
  bottom: 48px;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(89, 204, 214, 0), rgba(89, 204, 214, 0.95), rgba(31, 78, 121, 0));
}

.solution-blueprint article {
  position: relative;
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 4px 18px;
  align-content: center;
  min-height: 0;
  padding: 20px 22px;
  border: 1px solid rgba(31, 78, 121, 0.12);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(232, 244, 252, 0.86));
  box-shadow: 0 16px 44px rgba(31, 78, 121, 0.1);
}

.solution-blueprint article::before {
  content: "";
  position: absolute;
  left: clamp(18px, 3vw, 24px);
  top: 50%;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--white);
  border: 1px solid rgba(31, 78, 121, 0.14);
  transform: translateY(-50%);
  box-shadow: inset 0 0 0 10px rgba(89, 204, 214, 0.18);
}

.solution-blueprint span {
  position: relative;
  z-index: 1;
  grid-row: span 2;
  align-self: center;
  color: var(--teal-dark);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  font-weight: 950;
  text-align: center;
}

.solution-blueprint strong {
  color: var(--navy);
  font-size: clamp(21px, 2.2vw, 30px);
  line-height: 1.05;
}

.solution-blueprint p {
  margin: 0;
  color: rgba(21, 36, 59, 0.64);
  font-size: 15px;
  font-weight: 750;
  line-height: 1.35;
}

@media (max-width: 680px) {
  .solution-blueprint {
    height: auto;
  }

  .solution-blueprint article {
    grid-template-columns: 54px minmax(0, 1fr);
    padding: 18px;
  }

  .blueprint-line {
    left: 44px;
  }
}

/* Resources coming soon page */
.resources-soon-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(360px, 0.96fr) minmax(420px, 1.04fr);
  gap: clamp(24px, 4vw, 46px);
  align-items: center;
  min-height: 82vh;
  padding: 116px clamp(18px, 4vw, 54px) 34px;
  overflow: hidden;
  background:
    linear-gradient(115deg, rgba(247, 251, 255, 0.98) 0%, rgba(239, 247, 252, 0.92) 56%, rgba(197, 220, 244, 0.58) 100%),
    url('./hero-crew-training.png') center / cover no-repeat;
}

.resources-soon-hero::before {
  content: "";
  position: absolute;
  width: 920px;
  height: 720px;
  left: -250px;
  top: 80px;
  opacity: 0.34;
  transform: rotate(-12deg);
  background:
    radial-gradient(circle at center, rgba(86, 199, 201, 0.22), transparent 28%),
    repeating-radial-gradient(ellipse at center, rgba(31, 78, 121, 0.2) 0 1px, transparent 1px 34px);
  pointer-events: none;
}

.resources-soon-copy,
.resource-build-card {
  position: relative;
  z-index: 1;
}

.resources-soon-copy {
  max-width: 760px;
}

.resources-soon-copy h1 {
  max-width: 920px;
  color: var(--navy);
  font-size: clamp(38px, 3.45vw, 48px);
  line-height: 1.03;
}

.resources-soon-copy > p:not(.eyebrow) {
  max-width: 690px;
  margin: 24px 0 0;
  color: rgba(47, 52, 72, 0.78);
  font-size: clamp(16px, 1.55vw, 20px);
  font-weight: 600;
  line-height: 1.45;
}

.resource-build-card {
  height: clamp(430px, 42vw, 530px);
  display: grid;
  align-content: space-between;
  gap: 18px;
  padding: clamp(22px, 3vw, 34px);
  border: 1px solid rgba(31, 78, 121, 0.14);
  border-radius: var(--radius-lg);
  background: rgba(247, 251, 255, 0.76);
  box-shadow: var(--hard-shadow);
  backdrop-filter: blur(18px);
}

.build-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(31, 78, 121, 0.12);
}

.build-status span {
  color: rgba(31, 78, 121, 0.72);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.build-status strong {
  padding: 11px 15px;
  border-radius: 999px;
  color: var(--navy);
  background: rgba(89, 204, 214, 0.28);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}

.build-list {
  display: grid;
  gap: 10px;
}

.build-list article {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  border: 1px solid rgba(31, 78, 121, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.74);
}

.build-list span {
  color: var(--teal-dark);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  font-weight: 950;
}

.build-list strong {
  color: var(--navy);
  font-size: clamp(18px, 1.7vw, 24px);
  line-height: 1.05;
}

.build-list em {
  color: rgba(21, 36, 59, 0.58);
  font-size: 12px;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
}

.resource-preview-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  padding: clamp(60px, 7vw, 96px) clamp(22px, 5vw, 72px);
  background: var(--midnight);
}

.resource-preview-strip article {
  min-height: 220px;
  padding: clamp(24px, 3vw, 34px);
  background: rgba(247, 251, 255, 0.08);
  border: 1px solid rgba(247, 251, 255, 0.1);
}

.resource-preview-strip span {
  color: var(--teal);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.resource-preview-strip p {
  margin: 46px 0 0;
  color: var(--white);
  font-size: clamp(21px, 2vw, 28px);
  font-weight: 850;
  line-height: 1.18;
}

@media (max-width: 980px) {
  .resources-soon-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-top: 112px;
  }

  .resource-build-card {
    height: auto;
  }

  .resource-preview-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .resources-soon-copy h1 {
    font-size: 32px;
  }

  .build-list article,
  .resource-preview-strip {
    grid-template-columns: 1fr;
  }
}

/* Homepage feature console preview */
.feature-console {
  display: grid;
  grid-template-columns: minmax(180px, 0.72fr) minmax(360px, 1.48fr) minmax(220px, 0.8fr);
  gap: 16px;
  width: min(100%, 1180px);
  margin: 0 auto;
  padding: 16px;
  border: 1px solid rgba(197, 220, 244, 0.14);
  border-radius: 30px;
  background:
    linear-gradient(145deg, rgba(10, 24, 40, 0.96), rgba(17, 50, 78, 0.92));
  box-shadow: 0 34px 90px rgba(0, 0, 0, 0.26);
}

.console-sidebar,
.console-workspace,
.console-signal-panel {
  min-width: 0;
}

.console-sidebar {
  display: grid;
  gap: 6px;
  align-content: start;
  padding: 10px;
  border: 1px solid rgba(197, 220, 244, 0.12);
  border-radius: 20px;
  background: rgba(247, 251, 255, 0.06);
}

.console-sidebar a {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 38px;
  padding: 9px 10px;
  border-radius: 12px;
  color: rgba(247, 251, 255, 0.72);
  font-size: 13px;
  font-weight: 850;
  text-decoration: none;
}

.console-sidebar a:first-child,
.console-sidebar a:hover,
.console-sidebar a:focus-visible,
.console-sidebar a:target {
  color: var(--navy);
  background: var(--ice);
}

.console-sidebar span {
  color: var(--teal);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 11px;
  font-weight: 950;
}

.console-sidebar a:first-child span,
.console-sidebar a:hover span,
.console-sidebar a:focus-visible span,
.console-sidebar a:target span {
  color: var(--teal-dark);
}

.console-workspace {
  display: grid;
  gap: 14px;
}

.console-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 54px;
  padding: 0 18px;
  border: 1px solid rgba(197, 220, 244, 0.12);
  border-radius: 18px;
  background: rgba(247, 251, 255, 0.08);
}

.console-toolbar span,
.console-toolbar strong {
  color: rgba(247, 251, 255, 0.72);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.console-toolbar strong {
  color: var(--teal);
}

.console-main-panel {
  min-height: 330px;
  padding: clamp(28px, 4vw, 48px);
  border: 1px solid rgba(197, 220, 244, 0.14);
  border-radius: 24px;
  background:
    linear-gradient(145deg, rgba(247, 251, 255, 0.96), rgba(197, 220, 244, 0.82));
}

.console-main-panel h3 {
  margin: 0;
  max-width: 680px;
  color: var(--navy);
  font-size: clamp(34px, 4vw, 58px);
  line-height: 0.98;
}

.console-main-panel p:not(.eyebrow) {
  max-width: 660px;
  margin: 24px 0 0;
  color: rgba(21, 36, 59, 0.68);
  font-size: clamp(16px, 1.5vw, 20px);
  font-weight: 750;
  line-height: 1.5;
}

.console-flow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 34px;
}

.console-flow span {
  padding: 10px 12px;
  border: 1px solid rgba(31, 78, 121, 0.12);
  border-radius: 999px;
  color: var(--navy);
  background: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 950;
}

.feature-console .console-main-panel {
  background:
    linear-gradient(145deg, rgba(247, 251, 255, 0.98), rgba(209, 229, 247, 0.95));
}

.feature-console .console-main-panel .eyebrow {
  color: var(--ocean);
}

.feature-console .console-main-panel h3 {
  color: #10213a;
  text-shadow: none;
}

.feature-console .console-main-panel p:not(.eyebrow) {
  color: rgba(16, 33, 58, 0.78);
}

.feature-console .console-flow span {
  color: #10213a;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(31, 78, 121, 0.2);
  box-shadow: 0 10px 26px rgba(31, 78, 121, 0.08);
}

.console-module-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.console-module-grid article {
  min-height: 112px;
  padding: 16px;
  border: 1px solid rgba(197, 220, 244, 0.12);
  border-radius: 18px;
  background: rgba(247, 251, 255, 0.08);
}

.console-module-grid span,
.console-signal-panel span {
  display: block;
  color: rgba(197, 220, 244, 0.68);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.console-module-grid strong {
  display: block;
  margin-top: 18px;
  color: var(--white);
  font-size: 18px;
  line-height: 1.12;
}

.console-signal-panel {
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  border: 1px solid rgba(197, 220, 244, 0.12);
  border-radius: 20px;
  background: rgba(247, 251, 255, 0.06);
}

.console-signal-panel .eyebrow {
  margin-bottom: 8px;
}

.console-signal-panel div {
  display: grid;
  gap: 8px;
  padding: 16px;
  border: 1px solid rgba(197, 220, 244, 0.12);
  border-radius: 16px;
  background: rgba(247, 251, 255, 0.08);
}

.console-signal-panel strong {
  color: var(--white);
  font-size: 24px;
  line-height: 1;
}

@media (max-width: 1050px) {
  .feature-console {
    grid-template-columns: 1fr;
  }

  .console-sidebar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .console-module-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .feature-console,
  .console-sidebar,
  .console-module-grid {
    grid-template-columns: 1fr;
  }
}

/* Homepage executive briefing over fleet graphic */
.fleet-briefing {
  position: relative;
  z-index: 1;
  display: grid;
  align-items: end;
  width: min(100%, 1180px);
  min-height: clamp(620px, 68vw, 760px);
  margin: 0 auto;
  overflow: hidden;
  border: 1px solid rgba(197, 220, 244, 0.18);
  border-radius: 30px;
  background: var(--navy);
  box-shadow: 0 30px 80px rgba(2, 12, 23, 0.34);
}

.fleet-briefing img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.05);
}

.fleet-briefing::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(2, 12, 23, 0.9), rgba(2, 12, 23, 0.48) 44%, rgba(2, 12, 23, 0.16)),
    linear-gradient(0deg, rgba(2, 12, 23, 0.84), transparent 56%);
}

.fleet-briefing::after {
  content: "";
  position: absolute;
  inset: 26px;
  z-index: 1;
  pointer-events: none;
  border: 1px solid rgba(197, 220, 244, 0.2);
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(93, 210, 224, 0.12) 0 1px, transparent 1px),
    linear-gradient(0deg, rgba(93, 210, 224, 0.1) 0 1px, transparent 1px);
  background-size: 92px 92px;
  mask-image: linear-gradient(90deg, transparent, #000 16%, #000 84%, transparent);
}

.fleet-briefing-copy,
.fleet-briefing-signals,
.fleet-briefing-actions {
  position: relative;
  z-index: 2;
  min-width: 0;
}

.fleet-briefing-copy {
  max-width: 730px;
  padding: clamp(34px, 5vw, 72px);
}

.fleet-briefing-copy h3 {
  margin: 0;
  color: var(--white);
  font-size: clamp(42px, 6vw, 82px);
  line-height: 0.94;
  letter-spacing: 0;
}

.fleet-briefing-copy p:not(.eyebrow) {
  max-width: 650px;
  margin: 22px 0 0;
  color: rgba(221, 235, 248, 0.82);
  font-size: clamp(17px, 1.6vw, 22px);
  font-weight: 760;
  line-height: 1.48;
}

.fleet-briefing-signals {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid rgba(197, 220, 244, 0.2);
  background: rgba(2, 12, 23, 0.5);
  backdrop-filter: blur(14px);
}

.fleet-briefing-signals a {
  min-height: 126px;
  padding: clamp(18px, 2.2vw, 28px);
  border-right: 1px solid rgba(197, 220, 244, 0.16);
  color: var(--white);
  text-decoration: none;
  transition: background 0.2s ease;
}

.fleet-briefing-signals a:last-child {
  border-right: 0;
}

.fleet-briefing-signals a:hover,
.fleet-briefing-signals a:focus-visible {
  background: rgba(93, 210, 224, 0.16);
}

.fleet-briefing-signals span,
.fleet-briefing-actions span {
  display: block;
  color: var(--teal);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.fleet-briefing-signals strong {
  display: block;
  max-width: 220px;
  margin-top: 14px;
  font-size: clamp(18px, 1.8vw, 25px);
  line-height: 1.08;
}

.fleet-briefing-actions {
  position: absolute;
  right: clamp(28px, 4vw, 58px);
  top: clamp(32px, 5vw, 76px);
  width: min(330px, calc(100% - 56px));
  padding-left: 22px;
  border-left: 3px solid var(--teal);
}

.fleet-briefing-actions strong {
  display: block;
  margin-top: 12px;
  color: rgba(247, 251, 255, 0.92);
  font-size: clamp(18px, 1.9vw, 26px);
  line-height: 1.18;
}

@media (max-width: 900px) {
  .fleet-briefing {
    min-height: auto;
  }

  .fleet-briefing img {
    height: 52%;
    object-position: center top;
  }

  .fleet-briefing::before {
    background:
      linear-gradient(0deg, rgba(2, 12, 23, 0.98) 0 48%, rgba(2, 12, 23, 0.42)),
      linear-gradient(90deg, rgba(2, 12, 23, 0.78), rgba(2, 12, 23, 0.16));
  }

  .fleet-briefing-copy {
    padding-top: 320px;
  }

  .fleet-briefing-actions {
    position: relative;
    right: auto;
    top: auto;
    width: auto;
    margin: 0 clamp(28px, 5vw, 54px) 28px;
  }

  .fleet-briefing-signals {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  .fleet-briefing {
    border-radius: 24px;
  }

  .fleet-briefing::after {
    inset: 16px;
    border-radius: 18px;
  }

  .fleet-briefing-copy {
    padding: 260px 24px 28px;
  }

  .fleet-briefing-signals {
    grid-template-columns: 1fr;
  }

  .fleet-briefing-signals a {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(197, 220, 244, 0.16);
  }

  .fleet-briefing-signals a:last-child {
    border-bottom: 0;
  }

  .fleet-briefing-actions {
    margin: 0 24px 26px;
  }
}

/* Site-wide readability and homepage section CTAs */
.section-read-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: fit-content;
  min-height: 50px;
  margin-top: 28px;
  padding: 14px 22px;
  border: 1px solid rgba(21, 36, 59, 0.12);
  border-radius: 999px;
  color: var(--white) !important;
  background: var(--navy);
  box-shadow: 0 18px 42px rgba(21, 36, 59, 0.18);
  font-size: 15px;
  font-weight: 950;
  line-height: 1;
  text-decoration: none;
  text-shadow: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.section-read-more::after {
  content: "→";
  color: currentColor;
  font-size: 18px;
  line-height: 1;
}

.section-read-more:hover,
.section-read-more:focus-visible {
  transform: translateY(-2px);
  background: var(--ocean);
  box-shadow: 0 22px 48px rgba(31, 78, 121, 0.24);
}

.section-cta-row {
  display: flex;
  justify-content: center;
  width: min(100%, 1180px);
  margin: 24px auto 0;
}

.section-read-more.inverse {
  color: var(--white) !important;
  background: #10213a;
  border-color: rgba(115, 237, 243, 0.58);
  box-shadow: 0 18px 44px rgba(2, 12, 23, 0.28);
}

.section-read-more.inverse:hover,
.section-read-more.inverse:focus-visible {
  color: #061421 !important;
  background: #73edf3;
}

.solution-schema .section-heading h2,
.features .section-heading h2,
.testimonial h2,
.solution-lanes h2,
.solution-lanes h3 {
  color: var(--white);
}

.solution-schema .section-heading p,
.features .section-heading p,
.testimonial .testimonial-role,
.solution-lanes .section-heading p {
  color: rgba(247, 251, 255, 0.86);
}

.feature-console,
.fleet-briefing,
.solution-schema,
.solution-lanes,
.testimonial {
  color: var(--white);
}

.outcomes,
.outcomes .section-heading,
.outcomes .section-heading h2 {
  color: #10213a;
}

.outcomes .section-heading .eyebrow {
  color: #1f5f8f;
}

.outcomes .section-heading p {
  color: rgba(16, 33, 58, 0.78);
}

.console-sidebar a,
.console-toolbar span,
.console-toolbar strong,
.console-module-grid span,
.console-signal-panel span,
.fleet-briefing-copy p:not(.eyebrow),
.fleet-briefing-actions strong,
.command-readouts span {
  color: rgba(247, 251, 255, 0.88);
}

.console-toolbar strong,
.fleet-briefing-signals span,
.fleet-briefing-actions span,
.console-sidebar span,
.console-module-grid span,
.console-signal-panel span {
  color: #73edf3;
}

.console-module-grid strong,
.console-signal-panel strong,
.fleet-briefing-signals strong,
.command-readouts strong {
  color: var(--white);
}

.console-sidebar a:first-child,
.console-sidebar a:hover,
.console-sidebar a:focus-visible,
.console-sidebar a:target {
  color: #081827;
  background: #f7fbff;
}

.console-main-panel,
.feature-console .console-main-panel,
.fleet-card,
.resource-build-card,
.feature-page .module-card,
.platform-page .module-card,
.platform-page .platform-command,
.platform-page .platform-overview-grid article,
.about-page .model-steps article,
.solution-anchor-bar,
.resource-preview-strip article {
  color: #10213a;
}

.console-main-panel h3,
.feature-console .console-main-panel h3,
.fleet-card strong,
.resource-build-card h2,
.feature-page .module-card h3,
.platform-page .module-card h3,
.platform-page .platform-command h3,
.platform-page .platform-overview-grid h3,
.about-page .model-steps h3,
.resource-preview-strip p {
  color: #10213a;
}

.console-main-panel p:not(.eyebrow),
.feature-console .console-main-panel p:not(.eyebrow),
.resource-build-card p,
.feature-page .module-card p,
.platform-page .module-card p,
.platform-page .platform-command p,
.about-page .model-steps p {
  color: rgba(16, 33, 58, 0.82);
}

.fleet-briefing::before {
  background:
    linear-gradient(90deg, rgba(2, 12, 23, 0.96), rgba(2, 12, 23, 0.62) 48%, rgba(2, 12, 23, 0.28)),
    linear-gradient(0deg, rgba(2, 12, 23, 0.9), transparent 56%);
}

.fleet-briefing-signals {
  background: rgba(2, 12, 23, 0.72);
}

.fleet-briefing-actions {
  padding: 18px 0 18px 22px;
  background: linear-gradient(90deg, rgba(2, 12, 23, 0.56), transparent);
}

.resources-about .resource-block {
  color: #10213a;
}

.resources-about .resource-block h2,
.resources-about .resource-links a {
  color: #10213a;
}

.resources-about .about-page-link {
  color: var(--white) !important;
  background: #10213a;
  border: 1px solid rgba(31, 78, 121, 0.2);
  box-shadow: 0 18px 42px rgba(16, 33, 58, 0.16);
}

.resources-about .about-page-link:hover,
.resources-about .about-page-link:focus-visible {
  color: #061421 !important;
  background: #73edf3;
}

.resources-about .resource-block p:not(.eyebrow),
.resources-about .about-signal span {
  color: rgba(16, 33, 58, 0.78);
}

/* Homepage typography scale */
main#home {
  --home-eyebrow: 12px;
  --home-body: clamp(16px, 1.35vw, 19px);
  --home-body-small: 15px;
  --home-section-title: clamp(34px, 4vw, 54px);
  --home-component-title: clamp(24px, 2.8vw, 38px);
  --home-card-title: clamp(20px, 2vw, 26px);
  --home-hero-title: clamp(38px, 4.4vw, 58px);
  --home-display-title: clamp(38px, 4.7vw, 64px);
  --home-label: 12px;
}

main#home .eyebrow,
main#home .slide-count,
main#home .spotlight-preheader,
main#home .console-toolbar span,
main#home .console-toolbar strong,
main#home .console-module-grid span,
main#home .console-signal-panel span,
main#home .fleet-briefing-signals span,
main#home .fleet-briefing-actions span,
main#home .testimonial-role,
main#home .resource-links span,
main#home .demo-form label {
  font-size: var(--home-eyebrow);
  letter-spacing: 0.08em;
}

main#home .hero h1 {
  font-size: var(--home-hero-title);
  line-height: 0.95;
}

main#home .hero-copy,
main#home .section-heading p:not(.eyebrow),
main#home .split p,
main#home .fleet-briefing-copy p:not(.eyebrow),
main#home .testimonial-content blockquote p,
main#home .resource-block p,
main#home .demo-copy p {
  font-size: var(--home-body);
  line-height: 1.5;
}

main#home .section-heading h2,
main#home .platform h2,
main#home .outcomes .section-heading h2,
main#home .resource-block h2,
main#home .demo-copy h2 {
  font-size: var(--home-section-title);
  line-height: 1;
}

main#home .fleet-briefing-copy h3,
main#home .testimonial-content h2 {
  font-size: var(--home-display-title);
  line-height: 0.98;
}

main#home .console-main-panel h3,
main#home .feature-console .console-main-panel h3,
main#home .solution-spotlight h3 {
  font-size: var(--home-component-title);
  line-height: 1.04;
}

main#home .pillar-grid h3,
main#home .orbit-notes h3,
main#home .console-module-grid strong,
main#home .console-signal-panel strong,
main#home .fleet-briefing-signals strong,
main#home .resource-links a {
  font-size: var(--home-card-title);
  line-height: 1.14;
}

main#home .about-signal span {
  font-size: 13px;
  line-height: 1;
  letter-spacing: 0.1em;
  padding: 10px 14px;
}

main#home .pillar-grid p,
main#home .orbit-notes p,
main#home .console-main-panel p:not(.eyebrow),
main#home .feature-console .console-main-panel p:not(.eyebrow),
main#home .console-flow span,
main#home .lifecycle span,
main#home .outcome-row span,
main#home .demo-form input,
main#home .demo-form button {
  font-size: var(--home-body-small);
}

main#home .dash-panel strong,
main#home .hero-metrics dd {
  font-size: var(--home-label);
}

main#home .hero-metrics dt,
main#home .dash-panel em {
  font-size: clamp(28px, 3.2vw, 42px);
}

main#home .orbit-core strong {
  font-size: clamp(22px, 2vw, 28px);
}

main#home .orbit-core span {
  font-size: 12px;
}

main#home .testimonial-carousel,
main#home .testimonial-carousel .testimonial-content,
main#home .testimonial-carousel .testimonial-content h2,
main#home .testimonial-carousel [data-testimonial-name] {
  color: #10213a;
}

main#home .testimonial-carousel .testimonial-content .eyebrow {
  color: #1f5f8f;
}

main#home .testimonial-carousel .testimonial-role,
main#home .testimonial-carousel [data-testimonial-role] {
  color: rgba(16, 33, 58, 0.72);
}

main#home .testimonial-carousel .testimonial-content blockquote p,
main#home .testimonial-carousel [data-testimonial-quote] {
  color: rgba(16, 33, 58, 0.82);
}

@media (max-width: 720px) {
  main#home {
    --home-hero-title: 34px;
    --home-section-title: 30px;
    --home-display-title: 32px;
    --home-component-title: 26px;
    --home-card-title: 20px;
    --home-body: 15px;
    --home-body-small: 14px;
  }
}
